➤ O documento discute filas (queues) como uma estrutura de dados, incluindo a definição de filas, o comportamento FIFO (first-in, first-out), e como implementar operações básicas como enfileirar (queue), espiar (peek) e desenfileirar (dequeue) elementos. Também apresenta a API Java Queue e PriorityQueue para filas.
33. DESENFILEIRAR ELEMENTO (DEQUEUE)
public T desenfileira(){
if (this.estaVazia()){
return null;
}
T objetoRemovido = this.elementos[0];
this.remove(0);
return objetoRemovido;
}
34. TESTE
Fila<Integer> fila = new Fila<>();
fila.enfileira(3);
fila.enfileira(1);
fila.enfileira(2);
System.out.println(fila.desenfileira()); //3
System.out.println(fila.desenfileira()); //1
35. FILAS (QUEUES): INTRODUÇÃO
➤ Classe Fila
➤ Definição ✅
➤ Enfileirar elemento ✅
➤ Espiar/Verificar elemento início da fila ✅
➤ Desenfileirar elemento da fila ✅
➤ API Java Queue
➤ Filas com prioridade
➤ API Java PriorityQueue
➤ Exercícios
36. FILAS (QUEUES)
API Java Queue + LinkedList
23
Estrutura de Dados e
Algoritmos com Java
<loiane.training />
37. TESTE
Queue<Integer> fila = new LinkedList<>();
fila.add(3);
fila.add(2);
fila.add(1);
System.out.println(fila);
fila.remove();
System.out.println(fila);
System.out.println(fila.peek());
38. FILAS (QUEUES): INTRODUÇÃO
➤ Classe Fila
➤ Definição ✅
➤ Enfileirar elemento ✅
➤ Espiar/Verificar elemento início da fila ✅
➤ Desenfileirar elemento da fila ✅
➤ API Java Queue ✅
➤ Filas com prioridade
➤ API Java PriorityQueue
➤ Exercícios
39. FILAS (QUEUES)
Filas com prioridade
24
Estrutura de Dados e
Algoritmos com Java
<loiane.training />
40. FILA COM PRIORIDADE
public class FilaComPrioridade<T> extends Fila<T>{
public void enfileira(T elemento) {
Comparable<T> chave = (Comparable<T>) elemento;
int i;
for (i=0; i<this.tamanho; i++){
if (chave.compareTo(this.elementos[i]) < 0) {
break;
}
}
super.adiciona(i, elemento);
}
}
41. TESTE
public class Pessoa implements Comparable<Pessoa>{
private String nome;
private int prioridade;
@Override
public int compareTo(Pessoa o) {
if (prioridade > o.prioridade){
return 1;
} else if (prioridade < o.prioridade){
return -1;
}
return 0;
}
}