设计一个算法,删除顺序链表中值为X的所有结点

guopai123 2011-12-27 08:08:26
设计一个算法,删除顺序链表中值为X的所有结点
...全文
2539 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
fyk810888 2011-12-27
  • 打赏
  • 举报
回复
楼上的正解
金元520 2011-12-27
  • 打赏
  • 举报
回复 1
p=head;
while(x==head->data)
{
head=head->next;
free(p); // delete p;
p=head;
}
node *q=NULL;
if(p)q=p->next;
while(q)
{
if(x==q->data)
{
p->next=p->next->next;
free(q); // delete q;
}
else
p=p->next;
q=p->next;
}


未调试 不知道对不对
金元520 2011-12-27
  • 打赏
  • 举报
回复
p=head;
while(x==head->data)
{
head=head->next;
free(p); // delete p;
p=head;
}
node *q=NULL;
if(p)q=p->next;
while(q)
{
if(x==q->data)
{
p->next=p->next->next;
free(q); // delete q;
}
else
p=p->next;
q=p->next;
}

没高度 不知道对不对
阿尔博特 2011-12-27
  • 打赏
  • 举报
回复
先遍历找到值为x的结点,找不到就返回false,找到就用两个指针把他删了,p指向值为x的结点,q指向该结点的前一结点,然后用q->next = p->next;delete p;
阿尔博特 2011-12-27
  • 打赏
  • 举报
回复
先遍历找到值为x的结点,找不到就返回false,找到就用两个指针把他删了,p指向值为x的结点,q指向该结点的前一结点,然后用q->next = p->next;delete p;

64,647

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧