C_C程序设计李云峰第7章节利用构造类型编程幻灯片.pptVIP

C_C程序设计李云峰第7章节利用构造类型编程幻灯片.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
馋死 PPT研究院 POWERPOINT ACADEMY * * 7.2.2 链表结点定义与动态存储 struct 结点名 { 数据域 引用域 }; 链表通常被设计为结构类型, 并动态分配存储空间,即利 用函数开辟或回收存储单元。 在建立一个链表前,必须先定义 链表结点,结点定义包括普通结点定义和头结点定义。 1、普通结点定义 普通结点定义包括数据域和引用域两部分。结构体定义单 链表普通结点的一般形式为: 2、头结点的定义 单链表中,头结点仅含有引用域,通常使用header来表示。 因此,头结点可以使用一个结构体指针来表示。结构体定义单 链表头结点的一般形式为: struct 结点名 *header 3、建立与删除结点的函数 链表是一个动态的存储结构, 在建立链表时, 链表上的 每个结点不是预先定义好了的,而是需要时可以随时从内存中 申请,不需要时可以随时释放。 7.2.2 链表结点定义与动态存储 7.2.3 链表的建立 链表是一种动态结构,它是通过指向链表第一个结点的指针访问的,它指向链表在内存中的首地址,其后的结点是通过头结点中的next指针成员访问的。链表最后一个结点中的next域值通常被设置为NULL,用来表示链表尾。建立链 表通常有两种方法: ⑴ 表尾添加法:从一个空表开始,将生成的新结点插入到 当前链表的表尾,直至建立所有的结点。 ⑵ 表头添加法:从一个空表开始,将生成的新结点插入到 当前链表的表头,直至建立所有的结点。 7.2.4 链表的输出 链表的输出就是将链表中各结点的数据依次输出。首先 必须知道链表中第一个结点的地址。然后使p指向下一结点, 输出下一结点数据成员的值,其步骤可描述为: Step1:判断链表头指针head是否为NULL,若head为NULL,则输出“链表为空”信息,然后结束;若head不为空,则执行Step2。 Step3:判断p是否为NULL,若p不为NULL,则执行Stepf,否则结束循环; Step2:令一指针变量p,并对p赋值为head,即p=head; Step4:输出p数据成员的值,然后使p指向下一结点,即p=p-next;再转Step3。 1 4 2 3 7.2.5 链表的插入 链表的插入就是将一个新结点插入到一个已有链表的适当位置。 在一个链表中插入结点的具体步骤可描述为: Step1:查找要插入新结点的位置;若没有找到要插入的位置,则插入到表尾; Step3:将新结点的next指向前一个结点的next指向的结点; Step2:用malloc函数向系统申请分配一个结点空间,并赋值; Step4:将前一个结点的next指向新结点。 1 3 2 4 7.2.6 链表的删除 Step2:将前一个结点的next指向要删除结点的next指向的结点。 Step1:判断链表的头指针head是否为NULL,若head为NULL,则输出“链表为空” Step3:用free函数释放本结点。 1 2 3 链表的删除就是将链表中的某个指定的结点从链表中分 离出来,不再与链表的其它结点有任何联系,并且释放已删 除结点所占据的内存空间。删除一个链表结点的步骤描述为: 7.2.7 链表的合并 两个链表合并的操作原理类似于站队,两排站好的队伍, 想合并为一排,则需要依次取每个队伍中最矮的人排到新队伍 的后面,这样最后完成的队伍就是两个队伍的完美合并。 【实例7-6】合并两个链表。 建立两个带头结点的有序 单链表La,Lb(单调递增),利用La,Lb的结点空间,将La和 Lb合并成一个按元素值递增的有序单链表Lc。 [问题分析] 建两个顺序链表La表和Lb表, 扫描La 和Lb中的元素,比较当前元素的值,将较小者链到*r后,如此 重复直到La和Lb比较结束,再将另一个链表余下的内容链到r 所指的结点后。程序需要三个指针,分别为p,q,r, 其中p, q指向La表、Lb表的首结点,用p遍历La表, q遍历Lb表,r指 向合并后的新表的最后一个结点,r的初值指向La表的头结点。 7.2.7 链表的合并 [程序实现] struct node *Union(struct node *heada, s

文档评论(0)

带头大哥 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档