0

我有一个单链表,其中节点和列表结构定义为:

typedef struct _node
{
   int data;
   node* next;
} node;

typedef struct _list
{
   node* start;
} list;

我编写了一个函数来从列表中删除特定值的前导条目,但它似乎没有按预期工作。在运行我的函数并重新打印我的列表后,该元素不再存在,而是在其位置上有一个很大的值(大约 134520848)。我删除定义值的前导值的功能是:

void removeLead(list* l, int n)
{
   node* current = l->start;
   node* temp = NULL;

   while (current->data == n)
   {
      temp = current;
      l->start = current->next;
      free(temp);
   }
}

如果我有 4 个前导值 == n,那么在运行之后removeLead(),我有 3 个前导条目 ~134520848。

4

1 回答 1

3

代码中有错误。您没有重新分配当前变量。

void removeLead(list* l, int n)
{
   node* current = l->start;
   node* temp = NULL;

   while (current->data == n)
   {
      temp = current;
      current = current->next;
      if(l->start == temp)
          l->start = current;
      free(temp);
   }
}
于 2012-06-21T04:09:34.987 回答