Deque (estruturas de dados): diferenças entre revisões

Origem: Wikipédia, a enciclopédia livre.
Conteúdo apagado Conteúdo adicionado
DannyS712 (discussão | contribs)
m <source> -> <syntaxhighlight> (phab:T237267)
Linha 1: Linha 1:
{{Ver desambig||Deque}}
{{Ver desambig||Deque}}
{{Sem-fontes||ci|data=setembro de 2010}}
{{mais fontes|data=dezembro de 2020}}
Em [[ciência da computação]], uma '''Fila Duplamente Terminada''' (frequentemente abreviada como '''DEQUE''', do inglês '''D'''ouble '''E'''nded '''Que'''ue) é um [[tipo de dado abstrato]] que generaliza uma [[fila]], para a qual os elementos podem ser adicionados ou removidos da frente (cabeça) ou de trás (cauda). Também é chamada de '''lista encadeada cabeça-cauda''', apesar de propriamente isto se referir a uma [[implementação]] de [[estrutura de dados]] específica.
Em [[ciência da computação]], uma '''Fila Duplamente Terminada''' (frequentemente abreviada como '''DEQUE''', do inglês '''D'''ouble '''E'''nded '''Que'''ue) é um [[tipo de dado abstrato]] que generaliza uma [[fila]], para a qual os elementos podem ser adicionados ou removidos da frente (cabeça) ou de trás (cauda).<ref>[[Donald Knuth]]. ''[[The Art of Computer Programming]]'', Volume 1: ''Fundamental Algorithms'', Third Edition. Addison-Wesley, 1997. {{ISBN|0-201-89683-4}}. Section 2.2.1: Stacks, Queues, and Deques, pp. 238&ndash;243.</ref> Também é chamada de '''lista encadeada cabeça-cauda''', apesar de propriamente isto se referir a uma [[implementação]] de [[estrutura de dados]] específica.


As deques são [[FIFO|filas]] duplamente ligadas, isto é, filas com algum tipo de prioridade. Por exemplo, [[Computação distribuída|sistemas distribuídos]] sempre necessitam que algum tipo de [[processador|processamento]] seja mais rápido, por ser mais prioritário naquele momento, deixando outros tipos mais lentos ou em fila de espera, por não requerem tanta pressa. Ele pode ser entendido como uma extensão da estrutura de dados Fila.
As deques são [[FIFO|filas]] duplamente ligadas, isto é, filas com algum tipo de prioridade. Por exemplo, [[Computação distribuída|sistemas distribuídos]] sempre necessitam que algum tipo de [[processador|processamento]] seja mais rápido, por ser mais prioritário naquele momento, deixando outros tipos mais lentos ou em fila de espera, por não requerem tanta pressa. Ele pode ser entendido como uma extensão da estrutura de dados Fila.
Linha 26: Linha 26:
A Deque é dividida pelo total de posições em duas extremidades, onde o total não pode ser extrapolado, senão ocorre o estouro da memória, que já foi programada para uma determinada quantidade, não havendo possibilidade de mudança após já se ter definido o total. Os primeiros que são inseridos são os últimos a serem retirados, e é possível inserir elementos em ambos os lados (tanto no seu início como no seu final) mesmo que desproporcionalmente, desde que não ultrapasse o limite máximo.
A Deque é dividida pelo total de posições em duas extremidades, onde o total não pode ser extrapolado, senão ocorre o estouro da memória, que já foi programada para uma determinada quantidade, não havendo possibilidade de mudança após já se ter definido o total. Os primeiros que são inseridos são os últimos a serem retirados, e é possível inserir elementos em ambos os lados (tanto no seu início como no seu final) mesmo que desproporcionalmente, desde que não ultrapasse o limite máximo.


{{Referências}}



{{esboço-programação}}
{{esboço-programação}}

{{Estrutura de dados}}
{{Estrutura de dados}}



Revisão das 13h05min de 3 de dezembro de 2020

 Nota: Para outros significados, veja Deque.

Em ciência da computação, uma Fila Duplamente Terminada (frequentemente abreviada como DEQUE, do inglês Double Ended Queue) é um tipo de dado abstrato que generaliza uma fila, para a qual os elementos podem ser adicionados ou removidos da frente (cabeça) ou de trás (cauda).[1] Também é chamada de lista encadeada cabeça-cauda, apesar de propriamente isto se referir a uma implementação de estrutura de dados específica.

As deques são filas duplamente ligadas, isto é, filas com algum tipo de prioridade. Por exemplo, sistemas distribuídos sempre necessitam que algum tipo de processamento seja mais rápido, por ser mais prioritário naquele momento, deixando outros tipos mais lentos ou em fila de espera, por não requerem tanta pressa. Ele pode ser entendido como uma extensão da estrutura de dados Fila.

A implementação de um deque por alocação estática ou seqüencial é feita por meio de um arranjo de dimensão máxima predefinida e de duas variáveis inteiras que indicam o topo e a base (head e tail, respectivamente). Da mesma forma que ocorre com a fila, o deque deve ser implementado segundo a abordagem circular, que confere eficiência à estrutura ao mesmo tempo em que evita o desperdício de memória.

A declaração em C++ adotada para o deque implementado por arranjo é:

#define MAXDEQUE <tamanho máximo deque>
struct deque {
  tipo itens[MAXDEQUE];
  int inicio_esq, inicio_dir;
};
                          pont. esq.   pont. dir.                             
                                 |      |
 Overflow	[A]	[B]	[C]	[D]	[E]	[F]	overflow
                1       2       3       4       5       6
                 |              |        |               |
            (ini. esq)     (fim. esq)  (ini. dir)      (fim dir.)

A Deque é dividida pelo total de posições em duas extremidades, onde o total não pode ser extrapolado, senão ocorre o estouro da memória, que já foi programada para uma determinada quantidade, não havendo possibilidade de mudança após já se ter definido o total. Os primeiros que são inseridos são os últimos a serem retirados, e é possível inserir elementos em ambos os lados (tanto no seu início como no seu final) mesmo que desproporcionalmente, desde que não ultrapasse o limite máximo.

Referências

  1. Donald Knuth. The Art of Computer Programming, Volume 1: Fundamental Algorithms, Third Edition. Addison-Wesley, 1997. ISBN 0-201-89683-4. Section 2.2.1: Stacks, Queues, and Deques, pp. 238–243.
Ícone de esboço Este artigo sobre programação de computadores é um esboço. Você pode ajudar a Wikipédia expandindo-o.