Wikipedia for Schools in Portuguese is available here
CLASSICISTRANIERI HOME PAGE - YOUTUBE CHANNEL
SITEMAP
Make a donation: IBAN: IT36M0708677020000000008016 - BIC/SWIFT:  ICRAITRRU60 - VALERIO DI STEFANO or
Privacy Policy Cookie Policy Terms and Conditions
Lista ligada - Wikipédia

Lista ligada

Origem: Wikipédia, a enciclopédia livre.

Uma lista ligada é uma estrutura de dados linear e dinâmica. Ela é composta por células que apontam para o próximo elemento da lista. Para "ter" uma lista ligada, basta guardar seu primeiro elemento, e seu último elemento aponta para uma célula nula. O esquema a seguir representa uma lista ligada com 5 elementos:

Célula 1 ---> Célula 2 ---> Célula 3 ---> Célula 4 ---> Célula 5 ---> (Nulo)

Para manipularmos estas listas nomeadamente: inserir dados ou remover dados temos que ter sempre em atenção em ter um ponteiro que aponte para o 1º elemento e outro que aponte para o fim, isto porque se queremos inserir ou apagar dados que estão no inicio ou no fim da lista então a operação é rápidamente executada caso seja um nó que esteja no meio da lista pois terá que haver uma procura até encontrar a posição desejada.

Diagrama conceitual de uma lista ligada.
Ampliar
Diagrama conceitual de uma lista ligada.

Índice

[editar] Vantagens

  • A inserção de um elemento no meio da lista não implica mover todos os elementos.

[editar] Desvantagens

  • O acesso sequencial, para eleminação ou inserção de um elemento no meio da lista.

[editar] Níveis de complexidade

A nível temporal temos as seguintes complexidades:

  • Inserção
    • Cabeça O(1)
    • Cauda O(1)
    • Meio O(n)
  • Eliminação
    • Cabeça O(1)
    • Cauda O(n)
    • Meio O(n)


[editar] Exemplo

Exemplo de um Código feito para um dicionário de palavras em linguagem de programação C:


struct dic{
    char *original;
    char *complementar;
    struct dic *prox;
};

struct dic* ini=NULL;
struct dic* last=NULL;

//adicionar um novo dic à nossa lista
void dic_add(char *original, char *complementar){
        
    //se last é igual a Null quer dizer que a lista está vazia
    if (last == NULL){
        // o elemento será o primeiro
        last = (struct dic*)malloc(sizeof(struct dic));
        (*last).original = original;
        (*last).complementar = complementar;
        // Definição da cabeça da fila
        ini = last;
    } else {
        // o elemento será o último
        (*last).prox = (struct dic*)malloc(sizeof(struct dic));
        last = (*last).prox;
        (*last).original = original;
        (*last).complementar = complementar;
    }        
}

//Percorrer e Imprimir a lista ligada
void dic_print(){
    int sair = 0;
    struct dic* act = ini;
   
    do {
        if (act == last)
            sair = 1;
        printf("----------------------------------------------\n");
        printf("original: %s\n",(*act).original);
        printf("complementar: %s\n",(*act).complementar);
        printf("prox: %d\n", (*act).prox);
        act = (*act).prox;
    } while(sair == 0);
    printf("----------------------------------------------");
}


[editar] Exemplo em Java

Exemplo de um Código feito para um dicionário de palavras em linguagem de programação Java:


import javax.swing.*;

class No
{
        int elemento;
        No prox;
        
        No (int elem){
                elemento = elem;
                prox = null;
        }
 }

class ListaLigada
{
        No primeiro, ultimo;
        
        ListaLigada ()
        {
                primeiro = null;
                ultimo = null;
        }
        
        public boolean ListaVazia()
        {
                if (primeiro == null && ultimo == null)
                {
                        return true;
                }
                else
                {
                        return false;
                }
        }
        
        public void InserirInicio(No novoNo)
        {
                if (ListaVazia())
                {
                        ultimo = novoNo;
                }
                else
                {
                        novoNo.prox = primeiro;
                }
                primeiro = novoNo;
        }
        
        public void InserirFinal(No novoNo)
        {
                if (ListaVazia())
                {
                        primeiro = novoNo;
                }
                else
                {
                        ultimo.prox = novoNo;
                }
                ultimo = novoNo;
        }
        
        public int ContarNos()
        {
                int tamanho = 0;
                No NoTemp = primeiro;
                
                while (NoTemp !=null)
                {
                        tamanho = tamanho+1;
                        NoTemp = NoTemp.prox;
                }
                return tamanho;
        }
        
        public void InserirMeio(No NovoNo, int posicao)
        {
                No NoTemp = primeiro;
                int NroNos, posAux = 1;
                
                NroNos = ContarNos();
                
                if(posicao <= 1)
                {
                        InserirInicio(NovoNo);
                }
                else
                {
                        if (posicao > NroNos)
                        {
                                InserirFinal(NovoNo);
                        }
                        else
                        {
                                while (posAux < (posicao -1))
                                {
                                        NoTemp = NoTemp.prox;
                                        posAux = posAux + 1;
                                }
                                NovoNo.prox = NoTemp.prox;
                                NoTemp.prox = NovoNo;
                        }
                }
        }
        
        public void Remover(int elemento)
        {
                No NoTemp = primeiro;
                No NoAnt = null;
                
                if (primeiro.elemento == elemento)
                {
                        primeiro = primeiro.prox;
                }
                else
                {
                        while (NoTemp !=null && NoTemp.elemento != elemento)
                        {
                                NoAnt = NoTemp;
                                NoTemp = NoTemp.prox;
                        }
                        
                        if(NoTemp != null)
                        {
                                NoAnt.prox = NoTemp.prox;
                        }
                        if(NoTemp == ultimo)
                        {
                                ultimo = NoAnt;
                        }
                }
        }
        
        public void ElementoInicio()
        {
                if(!ListaVazia())
                {
                        System.out.println("O primeiro elemento  "+primeiro.elemento);
                }
                else
                {
                        System.out.println("Lista ligada vazia");
                }
        }
        
        public void ElementoFinal()
        {
                if(!ListaVazia())
                {
                        System.out.println("O ltimo elemento  "+ultimo.elemento);
                }
                else
                {
                        System.out.println("Lista ligada vazia");
                }
        }
        
        public No BuscarNo (int elemento)
        {
                int i = 1;
                No NoTemp = primeiro;
                
                while (NoTemp !=null)
                {
                        if(NoTemp.elemento == elemento)
                        {
                                System.out.println("No "+ NoTemp.elemento + " posicao " +i);
                                return NoTemp;
                        }
                        i = i +1;
                        NoTemp = NoTemp.prox;
                }
                return null;
        }
        
        public void MostrarLista()
        {
                int i = 1;
                No NoTemp = primeiro;
                
                while (NoTemp !=null)
                {
                        System.out.println("Elemento " + NoTemp.elemento + " posicao " +i );
                        NoTemp = NoTemp.prox;
                        i = i +1;
                }
        }
}

class Exemplo1
{
        public static void main (String args[])
        {
                ListaLigada realLista = new ListaLigada();
                int i;
                int num;
                
                for (i = 1; i<=5; i++)
                {
                        num = Integer.parseInt(JOptionPane.showInputDialog("Digite um nr ")   );
                        realLista.InserirFinal(new No(num));
                }
                realLista.MostrarLista();
                System.exit(0);
        }
}

[editar] Texto de cabeçalho

==

[editar] Ver também

Static Wikipedia 2008 (no images)

aa - ab - af - ak - als - am - an - ang - ar - arc - as - ast - av - ay - az - ba - bar - bat_smg - bcl - be - be_x_old - bg - bh - bi - bm - bn - bo - bpy - br - bs - bug - bxr - ca - cbk_zam - cdo - ce - ceb - ch - cho - chr - chy - co - cr - crh - cs - csb - cu - cv - cy - da - de - diq - dsb - dv - dz - ee - el - eml - en - eo - es - et - eu - ext - fa - ff - fi - fiu_vro - fj - fo - fr - frp - fur - fy - ga - gan - gd - gl - glk - gn - got - gu - gv - ha - hak - haw - he - hi - hif - ho - hr - hsb - ht - hu - hy - hz - ia - id - ie - ig - ii - ik - ilo - io - is - it - iu - ja - jbo - jv - ka - kaa - kab - kg - ki - kj - kk - kl - km - kn - ko - kr - ks - ksh - ku - kv - kw - ky - la - lad - lb - lbe - lg - li - lij - lmo - ln - lo - lt - lv - map_bms - mdf - mg - mh - mi - mk - ml - mn - mo - mr - mt - mus - my - myv - mzn - na - nah - nap - nds - nds_nl - ne - new - ng - nl - nn - no - nov - nrm - nv - ny - oc - om - or - os - pa - pag - pam - pap - pdc - pi - pih - pl - pms - ps - pt - qu - quality - rm - rmy - rn - ro - roa_rup - roa_tara - ru - rw - sa - sah - sc - scn - sco - sd - se - sg - sh - si - simple - sk - sl - sm - sn - so - sr - srn - ss - st - stq - su - sv - sw - szl - ta - te - tet - tg - th - ti - tk - tl - tlh - tn - to - tpi - tr - ts - tt - tum - tw - ty - udm - ug - uk - ur - uz - ve - vec - vi - vls - vo - wa - war - wo - wuu - xal - xh - yi - yo - za - zea - zh - zh_classical - zh_min_nan - zh_yue - zu -

Static Wikipedia 2007 (no images)

aa - ab - af - ak - als - am - an - ang - ar - arc - as - ast - av - ay - az - ba - bar - bat_smg - bcl - be - be_x_old - bg - bh - bi - bm - bn - bo - bpy - br - bs - bug - bxr - ca - cbk_zam - cdo - ce - ceb - ch - cho - chr - chy - co - cr - crh - cs - csb - cu - cv - cy - da - de - diq - dsb - dv - dz - ee - el - eml - en - eo - es - et - eu - ext - fa - ff - fi - fiu_vro - fj - fo - fr - frp - fur - fy - ga - gan - gd - gl - glk - gn - got - gu - gv - ha - hak - haw - he - hi - hif - ho - hr - hsb - ht - hu - hy - hz - ia - id - ie - ig - ii - ik - ilo - io - is - it - iu - ja - jbo - jv - ka - kaa - kab - kg - ki - kj - kk - kl - km - kn - ko - kr - ks - ksh - ku - kv - kw - ky - la - lad - lb - lbe - lg - li - lij - lmo - ln - lo - lt - lv - map_bms - mdf - mg - mh - mi - mk - ml - mn - mo - mr - mt - mus - my - myv - mzn - na - nah - nap - nds - nds_nl - ne - new - ng - nl - nn - no - nov - nrm - nv - ny - oc - om - or - os - pa - pag - pam - pap - pdc - pi - pih - pl - pms - ps - pt - qu - quality - rm - rmy - rn - ro - roa_rup - roa_tara - ru - rw - sa - sah - sc - scn - sco - sd - se - sg - sh - si - simple - sk - sl - sm - sn - so - sr - srn - ss - st - stq - su - sv - sw - szl - ta - te - tet - tg - th - ti - tk - tl - tlh - tn - to - tpi - tr - ts - tt - tum - tw - ty - udm - ug - uk - ur - uz - ve - vec - vi - vls - vo - wa - war - wo - wuu - xal - xh - yi - yo - za - zea - zh - zh_classical - zh_min_nan - zh_yue - zu -

Static Wikipedia 2006 (no images)

aa - ab - af - ak - als - am - an - ang - ar - arc - as - ast - av - ay - az - ba - bar - bat_smg - bcl - be - be_x_old - bg - bh - bi - bm - bn - bo - bpy - br - bs - bug - bxr - ca - cbk_zam - cdo - ce - ceb - ch - cho - chr - chy - co - cr - crh - cs - csb - cu - cv - cy - da - de - diq - dsb - dv - dz - ee - el - eml - eo - es - et - eu - ext - fa - ff - fi - fiu_vro - fj - fo - fr - frp - fur - fy - ga - gan - gd - gl - glk - gn - got - gu - gv - ha - hak - haw - he - hi - hif - ho - hr - hsb - ht - hu - hy - hz - ia - id - ie - ig - ii - ik - ilo - io - is - it - iu - ja - jbo - jv - ka - kaa - kab - kg - ki - kj - kk - kl - km - kn - ko - kr - ks - ksh - ku - kv - kw - ky - la - lad - lb - lbe - lg - li - lij - lmo - ln - lo - lt - lv - map_bms - mdf - mg - mh - mi - mk - ml - mn - mo - mr - mt - mus - my - myv - mzn - na - nah - nap - nds - nds_nl - ne - new - ng - nl - nn - no - nov - nrm - nv - ny - oc - om - or - os - pa - pag - pam - pap - pdc - pi - pih - pl - pms - ps - pt - qu - quality - rm - rmy - rn - ro - roa_rup - roa_tara - ru - rw - sa - sah - sc - scn - sco - sd - se - sg - sh - si - simple - sk - sl - sm - sn - so - sr - srn - ss - st - stq - su - sv - sw - szl - ta - te - tet - tg - th - ti - tk - tl - tlh - tn - to - tpi - tr - ts - tt - tum - tw - ty - udm - ug - uk - ur - uz - ve - vec - vi - vls - vo - wa - war - wo - wuu - xal - xh - yi - yo - za - zea - zh - zh_classical - zh_min_nan - zh_yue - zu -

Sub-domains

CDRoms - Magnatune - Librivox - Liber Liber - Encyclopaedia Britannica - Project Gutenberg - Wikipedia 2008 - Wikipedia 2007 - Wikipedia 2006 -

Other Domains

https://www.classicistranieri.it - https://www.ebooksgratis.com - https://www.gutenbergaustralia.com - https://www.englishwikipedia.com - https://www.wikipediazim.com - https://www.wikisourcezim.com - https://www.projectgutenberg.net - https://www.projectgutenberg.es - https://www.radioascolto.com - https://www.debitoformtivo.it - https://www.wikipediaforschools.org - https://www.projectgutenbergzim.com