Jump to content
Sign in to follow this  
carlos870

Listas Ligadas

Recommended Posts

carlos870

Boas, o seguinte programa está a dar erro. Podem ajudar?

Eu sei que o erro que dá é na linha "(*lv)=ptr;", mas caso eu altere de modo a funcionar, o CodeBlocks dá Warnings e não pode dar (ordens do prof).

#include <stdio.h>
#include <stdlib.h>

typedef struct Veiculo{
        int num;
        struct Veiculo *prox;
}VEICULO;

typedef VEICULO * LISTAVEICULOS;


void insereVeiculo(int num, LISTAVEICULOS *lv)
{
    VEICULO *ptr;

    ptr=malloc(sizeof(VEICULO));

    if (ptr==NULL)
    {
        return;
    }

    ptr->num=num;
    ptr->prox=NULL;

    if (lv==NULL)
    {
        (*lv)=ptr;
    }
    else
    {
        (*lv)->prox=ptr;
    }
}

int main()
{
    LISTAVEICULOS *lv=NULL;

    insereVeiculo(5,lv);

    return 0;
}

Share this post


Link to post
Share on other sites
Baderous

Não dá warnings nenhuns, dá é segmentation fault ao executar. O erro está na instrução que indicaste, que tem de ser assim:

lv=&ptr;

Share this post


Link to post
Share on other sites
carlos870

Já dá, obrigado. Mas podias explicar o que faz o "&" aí? "lv" passa a apontar para o ponteiro de "ptr"?

Share this post


Link to post
Share on other sites
Baderous

Nessa instrução indica-se que lv passa a guardar o endereço de ptr. Uma vez que lv é um apontador para uma lista de veículos, ele vai guardar o endereço do início da lista.

Share this post


Link to post
Share on other sites
carlos870

Imaginando que eu quero introduzir outro veiculo:

insereVeiculo(10,lv);

Este já devia fazer com que fosse executada a instrução do "else". Mas isso não acontece e a lista continua apenas com um elemento. Podes ajudar?

Share this post


Link to post
Share on other sites
Baderous

Não estás a actualizar o lv para apontar sempre para o 1º elemento da lista.

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
Sign in to follow this  

×
×
  • Create New...

Important Information

By using this site you accept our Terms of Use and Privacy Policy. We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.