Ir ao conteúdo
  • Cadastre-se
Entre para seguir isso  
pxdc

Lista ligada de listas ligadas

Recommended Posts

Boas tenho um trabalho para fazer, que ainda está no inicio mas para poder avançar tenho que resolver um problema que estou a ter.

O enunciado é complexo por isso à medida que for avançando e for tendo dúvidas (espero que poucas) vou postando.

Quem quiser ter acesso ao trabalho pode dizer.

Eu pretendo (para já) adicionar vários "Cartões" com informações sobre os clientes e já fiz isso, o problema está na listagem que se pretende que seja imprimida por "id" um dos campos da struct.

Eis as structs:

typedef struct tipo2{
int cdg;
int quantidade;
float valor;
char descricaocompra [60];
struct tipo2 * seguinte;
} * Compra;

typedef struct tipo1{
char id[10];
float saldo;
char nome[50];
struct tipo1 * seguinte;
struct tipo2 * dados;
} * Cartao;

e a função listar:

void listar(Cartao c){
Cartao aux=c;
// Testar se a lista não é vazia
if (c != NULL){
// Se a lista circular contém somente uma célula
if (c == c -> seguinte){
printf("%s""%s""%.3f\n", c->id,c->nome,c->saldo);
}
// Senão se a lista circular contém pelo menos duas células
else
do{
printf("%s""%s""%.3f\n", aux->id,aux->nome,aux->saldo);
aux = aux->seguinte;
}
while(aux != NULL);
}
}

o problema é que ao listar ele lista a informação do cartão com id 1 e depois o que estiver à cabeça, ou seja, se inserir id1, id2, id3 ele dá-me a informação do id 1, id 3, id 2 e não 1,2,3..

Há alguma maneira de alterar esta função ou a "inserir" acima postada de modo a resolver isto?

Ou terei que criar um array de ids e depois ordena-los e imprimir a informação? Como faço isso?

Desde já agradeço toda a ajuda, pois estou a começar a programar.

Cumprimentos

Compartilhar este post


Link para o post
Compartilhar em outros sites

Sim, possivelmente será o caso.

Aqui fica a função inserir:

Cartao inserir(Cartao c, char * id, char * nome, float s=500){
Cartao novo;
novo=(Cartao)malloc(sizeof(struct tipo1));
strcpy( novo->id,id);
novo->saldo=s;
strcpy(novo->nome,nome);

if(c==NULL){
novo->seguinte=NULL;
return (novo);
}
else{
novo->seguinte=c->seguinte;
c->seguinte=novo;
return(c);
}
}

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

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar agora
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

×