我正在从迭代删除功能,从链表中删除节点,我认为代码应该工作正常,它遍历列表,找到所需的节点,指向头到下一个节点,并删除当前,但是当我试运行它,我得到无限循环,可以请你帮我查明错误,这里是功能:从链接列表中删除节点
typedef struct E_Type * List;
struct E_Type
{
int data;
struct E_Type* next;
};
功能:
bool erase(List & l, int data){
List head = l;
if (l != 0){
for(List current = head; current; current = current->next){
if (current->data == data)
head = current->next;
delete current;
return true;
}
}
return false;
}
测试程序:
int main()
{
List l = 0;
cout << boolalpha << l->data << "went well? "<< (insert(l,73)) << endl;
cout << boolalpha << l->data << "went well? "<< (insert(l,24)) << endl;
print(cout,l);
cout << boolalpha << "Is deleted 24? "<<(erase(l,24)) << endl;
cout << boolalpha << "Is deleted 35? "<<(erase(l,35)) << endl;
print(cout,l);
cout << endl;
return 0;
}
插入:
bool insert(List & l, int data)
{
List current = l;
while(current != 0) {
if (current->data == data)
return false;
current = current->next;
}
if (l == 0 || l->data > data){
List new_list = new E_Type;
new_list->data = data;
new_list->next = l;
l = new_list;
return true;
}
else if(l->data < data){
insert(l->next, data);
return true;
}
}
什么是List类型? –
对不起,我忘了粘贴typedef,现在它在那里 – EmilDo
我在'erase'中看到第二个'if'语句后面没有''''。这看起来是无意的;你有多个语句缩进后面。尝试将这些语句括在大括号中。 (仍然有错误,但看起来像是一个大问题,看起来像是无条件地删除了第一个条目。) – cHao