第7讲 链表-3幻灯片.pptVIP

  1. 1、本文档共18页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
循环链表的概念 循环链表的建立 循环链表的输出 循环链表的删除结点操作 循环链表的插入结点操作 双向链表的建立 * 第7讲 链表(3) 本讲内容: (1) 循环链表的概念 (2) 循环链表的建立和输出 (3) 循环链表的删除和插入结点操作 (4) 循环链表的尾指针 (5) 双向链表介绍 循环链表:表中最后一个结点的指针成员指向表头结点 整个链表形成一个环 95 1428 1 2010 86 1570 4 1428 82 NULL 9 1570 2010 head 2010 ST *creat(void) { ST *head, *p1, *p2; n=0; head=NULL; p1=(ST *) malloc ( LEN ); scanf(%d%d, p1-num, p1-score); while ( p1-num!=0 ) { n=n+1; if (n==1) head=p1; else p2-next=p1; p2=p1; p1=(ST *) malloc (LEN); scanf(%d%d, p1-num, p1-score); } p2-next = head; free(p1); return(head); } #includestdio.h #includestdlib.h typedef struct student { int num ; int score ; struct student *next ; }ST; #define LEN sizeof(ST) int n; void output (ST *head) { ST *p=head; while ( p-next!=head ) { printf(%3d %4d\n, p-num, p-score); p=p-next; } printf(%3d %4d\n, p-num, p-score); } 95 1428 1 2010 86 1570 4 1428 82 2010 9 1570 2010 head 2010 p 1428 1570 for( i=0; in; i++) // n为结点个数 { printf(%3d%4d\n, p-num, p-score); p=p-next; } 95 1428 1 2010 86 1570 2 1428 82 2010 3 1570 2010 head 1428 p1 2010 p2 删除中间结点 p2-next=p1-next; free(p1); 1570 循环链表的删除结点操作 95 1428 1 2010 86 1570 2 1428 82 2010 3 1570 2010 head 1570 p1 1428 p2 删除表尾结点 p2-next=p1-next; free(p1); 2010 循环链表的删除结点操作 95 1428 1 2010 86 1570 2 1428 82 2010 3 1570 2010 head 2010 p1 1570 q 删除表头结点 head=p1-next; q-next=head; free(p1); 1428 1428 q=head; while(q-next!=head) q=q-next; 让指针变量q指向表尾结点 95 2010 1 2010 2010 head 删除表头结点的操作: head=p1-next; q-next=head; free(p1); 2010 p1 2010 q 解决方法: 对这种特殊情况进行判断,判断p1和q是否相等,若相等,则令head为NULL 特殊情况:链表只有一个结点 执行以上操作后, 链表为空但head不为空 循环链表的删除结点操作 如何解决该问题? //删除表头结点的操作 //只有一个结点的情况 ST *del(ST *head, int num) { ST *p1,*p2,*q; p1=head; while((num!=p1-num)(p1-next!=head)) { p2=p1; p1=p1-next; } if(num==p1-num) { if (p1==head) { q=head; while(q-next!=head) q=q-n

文档评论(0)

mwk365 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档