在下面的代码中,当我在删除第一个元素后尝试显示列表时,它会导致下一个元素的无限循环。当除第一个元素被删除时,不会发生此问题。我不知道为什么会这样?有人可以告诉我错误在哪里吗?
#include<iostream>
using namespace std;
class node
{
public:
  int data;
  node *link;
};
class linkedlist
{  node *head;
public:
linkedlist()
{
   head=NULL;
}
    int add(int data1)
    { node *insertnode=new node;
        insertnode->data=data1;
        insertnode->link=NULL;
        node *temp=head;
        if(temp!=NULL)
        {
            while(temp->link!=NULL)
            {
                temp=temp->link;
            }
            temp->link=insertnode;
        }
        else{head=insertnode;}
    }
    void disp()
    { node *temp1=head;
    cout<<endl;
    if(temp1==NULL)
    {cout<<"Empty"<<endl;
    }
    if(temp1->link==NULL)
    {
        cout<<temp1->data<<endl;
    }
    else{
    do{cout<<temp1->data<<endl;
    temp1=temp1->link;
    }
    while(temp1!=NULL);
    }
    }
    int remove(int removedata)
    {
        node *temp2=head;
        if(temp2==NULL)
         {}
         if(temp2->link==NULL)
         {
             delete temp2;
             head=NULL;
         }
         else
         {
             node *previous;
             do
             {
                 if(temp2->data==removedata) break;
                 previous=temp2;
                 temp2=temp2->link;
             }while(temp2!=NULL);
            previous->link=temp2->link;
             delete temp2;
         }
    }
};
int main()
{
   linkedlist list;
   list.add(10);
   list.add(100);
   list.add(200);
   list.remove(10);
   list.disp();
}
谢谢你们。问题已解决