Ir ao conteúdo
  • Cadastre-se

Lista encadeada (dúvida)


leonardoadoado

Posts recomendados

typedef struct no

{ int valor;

struct no *proximo;

} tNo, *tLista;

tLista L = NULL;

void inserir_no_esquerda()

{ tLista P;

int valor;

printf("\n\nInserir no a esquerda\n\n");

printf("Digite um valor: ");

scanf("%d", &valor);

P = (tLista) malloc(sizeof(tNo));

P->valor = valor;

P->proximo = L;

L = P;

system("PAUSE");

}

void inserir_no_direita()

{ tLista P, Q;

int valor;

if (L == NULL)

{ // A lista está vazia

inserir_no_esquerda();

}

else

{ printf("\n\nInserir no a direita\n\n");

printf("Digite um valor: ");

scanf("%d", &valor);

P = L;

while (P->proximo != NULL)

P = P->proximo;

Q = (tLista) malloc(sizeof(tNo));

Q->valor = valor;

Q->proximo = NULL;

P->proximo = Q;

system("PAUSE");

}

}

Na parte em negrito, quando de coloca P=L, vamos supor que P = 1,2,3,4,NULL E L = 1,2,3,NULL. Qual o resultado disso P=L? Quem fica com o valor de quem?

Lembrando que P e L são ponteiros para tLista L em typedef no cabeçalho.

Aguardo resposta e obrigado.

Se for necessário, eu posto o algorítimo completo.

Link para o comentário
Compartilhar em outros sites

Galera, eu sei que ninguém respondeu, mas acho que pode fechar o tópido, pois eu acho que já entendi esse algorítimo. Em strutc, deve-se saber usar os ponteiros e saber para onde cada um deles está apontado. Pelo que eu entendi, quando se faz L=P, L está recebendo a posição do ponteiro P, e não os valores. Me corrijam qualquer enquívoco. valeu.

Link para o comentário
Compartilhar em outros sites

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas comunidades sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×
×
  • Criar novo...