Ir ao conteúdo
  • Comunicados

    • Gabriel Torres

      Seja um moderador do Clube do Hardware!   12-02-2016

      Prezados membros do Clube do Hardware, Está aberto o processo de seleção de novos moderadores para diversos setores ou áreas do Clube do Hardware. Os requisitos são:   Pelo menos 500 posts e um ano de cadastro; Boa frequência de participação; Ser respeitoso, cordial e educado com os demais membros; Ter bom nível de português; Ter razoável conhecimento da área em que pretende atuar; Saber trabalhar em equipe (com os moderadores, coordenadores e administradores).   Os interessados deverão enviar uma mensagem privada para o usuário @Equipe Clube do Hardware com o título "Candidato a moderador". A mensagem deverá conter respostas às perguntas abaixo:   Qual o seu nome completo? Qual sua data de nascimento? Qual sua formação/profissão? Já atuou como moderador em algo outro fórum, se sim, qual? De forma sucinta, explique o porquê de querer ser moderador do fórum e conte-nos um pouco sobre você.   OBS: Não se trata de função remunerada. Todos que fazem parte do staff são voluntários.
    • DiF

      Poste seus códigos corretamente!   21-05-2016

      Prezados membros do Fórum do Clube do Hardware, O Fórum oferece um recurso chamado CODE, onde o ícone no painel do editor é  <>     O uso deste recurso é  imprescindível para uma melhor leitura, manter a organização, diferenciar de texto comum e principalmente evitar que os compiladores e IDEs acusem erro ao colar um código copiado daqui. Portanto convido-lhes para ler as instruções de como usar este recurso CODE neste tópico:  
Entre para seguir isso  
leonardoadoado

Lista encadeada (dúvida)

Recommended Posts

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.

Editado por leonardoadoado

Compartilhar este post


Link para o post
Compartilhar em outros sites
  • Autor do tópico
  • 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.

    Compartilhar este post


    Link para o post
    Compartilhar em outros sites

    Crie uma conta ou entre para comentar

    Você precisar ser um membro para fazer um comentário

    Entre para seguir isso  





    Sobre o Clube do Hardware

    No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas publicações 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

    ×