Ir ao conteúdo
  • Cadastre-se

Problema para encontra um termo através da recurção em listas encadas


Gabriel_Moro

Posts recomendados

as funções q procuram e a função q recebe o retorno:
SETOREL *achaSet(char st[30], SETOREL *inicio) {
SETOREL *setEss = NULL;
if (inicio->nHierar != NULL || inicio->mHierar != NULL) {
if (strcmp(inicio->dadoS.setor,st) == 0) {
setEss = inicio;
} else {
if (inicio->nHierar != NULL) {
setEss = achaSet(st, inicio->nHierar);
} else if(inicio->mHierar!=NULL) {
setEss = achaSet(st, inicio->mHierar);
}
}
}
return setEss;
}

SETOREL *achaSetor(char st[30]) {
SETOREL *setEss = achaSet(st, inicio);
return setEss;
}

void addSetor(SETOR set) {
SETOREL *setEl;
setEl = (SETOREL *) malloc(sizeof(SETOREL));
setEl->dadoS = set;
setEl->mHierar = NULL;
setEl->nHierar = NULL;

if (inicio == NULL) {
inicio = setEl;
} else {
if (setEl->dadoS.hierarquia == 1) {
SETOREL *setEl1 = inicio;
while (setEl1->mHierar != NULL) {
setEl1 = setEl1->mHierar;
}
setEl1->mHierar = setEl;
} else {
char st[30];
printf("Digite em qual setor o %s sera vinculado: ",
setEl->dadoS.setor);
scanf("%[^\n]s", st);
fflush(stdin);
SETOREL *setEss;
setEss = achaSetor(st);
if (setEss != NULL) {
if (setEss->nHierar == NULL) {
setEss->nHierar = setEl;
} else {
setEss = setEss->nHierar;
while (setEss->mHierar != NULL) {
setEss = setEss->mHierar;
}
setEss->mHierar = setEl;
}
} else {
printf("O setor %s não foi encontrado.\n", st);
}
}
}
}

o programa completo ta no txt
um exemplo de falha na recurção ta na imagem
alguem saberia porque a recurção n encontra o termo procurado q existe na lista?multlist.txtmultlist.txt

capture-20170614-131915.png

Link para o comentário
Compartilhar em outros sites

Visitante
Este tópico está impedido de receber 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...