我有一个单链表,其中节点和列表结构定义为:
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。