| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 562 人关注过本帖
标题:关于链表的删除问题
只看楼主 加入收藏
feixiangmada
Rank: 1
等 级:新手上路
帖 子:6
专家分:6
注 册:2009-8-2
结帖率:0
收藏
已结贴  问题点数:20 回复次数:3 
关于链表的删除问题
从程序里截得一段
struct student *del(struct student *head, int del_num)
{
struct student *p1,*p2;
if(head == NULL)
  printf("\nlist null!!!\n"); /* 空表的情况 */
else
{
  p1 = head;
  while(del_num != p1->num && p1->next != NULL)
  {
   p2 = p1;
   p1 = p1->next; /* p1后移1个结点 */
  }
  if(del_num == p1->num) /* 找到 */
  {
   if(p1 == head) /* 若p1指向的是首结点 */
    head = p1->next;  /* 把第二个结点的地址赋予head */
   else
    p2->next = p1->next; /*将下一结点地址富裕前一结点地址 */
  }
  else
   printf("\n not found!!!\n");
}
return(head);
}
里面的while循环,问一下是怎么样查找到所要删除的序号的,总觉得}应该放在后面……
搜索更多相关主题的帖子: 链表 删除 
2009-08-02 17:12
黒渍
Rank: 2
等 级:论坛游民
帖 子:57
专家分:41
注 册:2009-7-16
收藏
得分:6 
没看懂你说的什么意思。。。

踏实学C
/*我的编程飞信群:9401431 互相学习,共同进步*/
2009-08-02 17:56
北冥云
Rank: 2
等 级:论坛游民
帖 子:38
专家分:32
注 册:2009-4-6
收藏
得分:6 
程序对的 p1是先导 p2是后继 这种技巧在链表中经常用
2009-08-02 18:33
紫ing~
Rank: 4
来 自:中科大
等 级:业余侠客
帖 子:103
专家分:273
注 册:2008-11-25
收藏
得分:6 
通过p1找到的,p2是删除节点时用的。

唯有天道恒在,往复循环,不曾更改。。。
2009-08-03 01:14
快速回复:关于链表的删除问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016613 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved