Ceci est mon code pour supprimer un noeud d'une liste chaînée.Suppression d'un noeud de la liste liée par index
vec_store
détient seq
et size
. La variable seq
contient les vecteurs et un pointeur.
Pour une raison quelconque, le else if(i<s->size-1)
ne fonctionne pas, ce qui est la dernière condition.
Quelqu'un peut-il résoudre le problème? D'ailleurs c'est le code C.
void delete_vec(vec_store s, int i)
{
if (i<0 || s->size-1<i)
{
printf("Cannot delete vector because index %d is out of bounds\n",i);
}
else if (i==0)
{
node temp;
temp = s->seq;
s->seq = s->seq->next;
s->size--;
free(temp);
}
else if(i==s->size-1)
{
node temp1, temp2;
//temp1 = malloc(sizeof (node));
temp2 = malloc(sizeof (node));
temp1=s->seq;
if(temp1->next==NULL)
{
free(temp1);
s->seq=NULL;
s->size--;
printf("s->size-1\n");
}
else
{
while (temp1->next!=NULL)
{
temp2 = temp1;
temp1 = temp1->next;
}
free(temp1);
temp2->next=NULL;
s->size--;
printf("s->size-1 2\n");
}
}
else if(i<s->size-1)
{
node temp1,temp2;
int j;
temp1=s->seq;
temp2 = malloc(sizeof (struct node_record));
for(j=0;j<=i-1;j++)
{
temp2=temp1;
temp1 = temp1->next;
}
free(temp1);
temp2->next=NULL;
s->size--;
}
}
Indentation correcte s'il vous plaît. –
Bonne nouvelle: Nous venons de recevoir un nouvel envoi de blancs, vous pouvez en utiliser autant que vous voulez! – caf
Une indentation incorrecte devrait générer des erreurs de compilation, cela me brûle les yeux. – Dave