链接列表(删除和搜索)
Linked Lists (Deletion and Searching)
以下伪代码从链表中删除一个节点。
void list::erase()//Deletes a node
{
cout<< "Enter a position: ";
cin>> pos;
if(pos==1)
{
current=head;
head=head->ptr;
}
else
{
current=head;
for(i=0; i<pos-1; i++)
{
temp=current;
current=current->ptr;
}
temp->ptr=current->ptr;
}
cout<< "Erased string: " << current->content<<"\t";
current=head;
while(current!=NULL)
{
cout<<current->content<<"\t";
current=current->ptr;
}
}
如果删除不在列表中的字符串,我需要显示一条消息:没有这样的字符串。我该怎么办?
以下伪代码在链表中搜索一个节点。
void list::search()//Searches a node
{
char str[50];
cout<<"Enter a string: ";
cin>> str;
current=head;
while(current!=NULL)
{
pos++;
if(!strcmp(current->content, str))
{
cout<< "Found at "<<pos;
}
current=current->ptr;
}
}
如果我在 list 中搜索 string not 并显示message相应:没有这样的字符串。我应该怎么办?请帮忙
在进入while loop
之前设置一个变量found= false
。只有在找到要查找的字符串时才更改变量的值,然后再进行打印:
found = false;
while(current!=NULL)
{
pos++;
if(!strcmp(current->content, str))
{
found = true;
break;
}
current=current->ptr;
}
if (found)
cout<< "Found at "<<pos;
else
cout<< "Not Found";