鱼C论坛

 找回密码
 立即注册
查看: 1743|回复: 1

这个算法从第二个链结点开始判断是否满足条件

[复制链接]
发表于 2018-11-6 10:10:21 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
这个算法从第二个链结点开始判断是否满足条件,最后再判断第一个链结点是否满足条件。相比于从第一个就开始判断是否满足条件,这样的做法意义在哪儿。
  1. //先从链表的第2个链结点开始,从前往后依次判断链表中所有链结点是否满足条件
  2. //若某个链结点满足条件,则删除该链结点,否则不做删除操作
  3. //最后再回过头判断链表中第1个链结点是否满足条件,若满足条件将其删除
  4. void DELETELIST (LinkList &list , ElemType item)
  5. {
  6.         /*list中存放链表的首地址*/
  7.         ListList p,q= list;
  8.         p = list->link;                                        /*p指向第2个链结点*/
  9.         while (p != NULL)
  10.         {
  11.                 if (p->data == item)                /*p指向的链结点满足条件*/
  12.                 {
  13.                         q->link = p->link;                /*删除p指向的链结点*/
  14.                         free(p);                                /*释放被删除链结点的存储空间*/
  15.                         p = q->link;                        /*p指向被删除链结点的下一个链结点*/
  16.                 }
  17.                 else
  18.                 {
  19.                         q = p;
  20.                         p = p->link;                        /*p指到下一个链结点*/
  21.                 }
  22.          }
  23.          if (list->dara == item)                /*第1个链结点满足条件*/
  24.          {
  25.                  q = list;
  26.                  list = list->link;                        /*删除第1个链结点*/
  27.                  free(q);
  28.          }
  29. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-11-12 21:59:51 | 显示全部楼层
首先看看头结点的作用:
链表加了头结点之后,插入、删除都是在后继指针next上进行操作,不用动头指针;若不加头指针的话,在第1个位置插入或者删除第1个元素时,需要动的是头指针,这将给后续操作带来麻烦。
如:
p指向链表头结点
if (p->data == item)  
p = p->link;
此时头结点已被删除,头指针移动,但头结点的空间没有被释放掉!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-28 13:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表