chapter10结构与联合.pptVIP

  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文档。上传文档
查看更多
chapter10结构与联合

本章要点 结构体的概念 结构体的定义和引用 结构体数组 用指针处理链表 主要内容 1 概述 2 定义结构体类型变量的方法 3 结构体变量的引用 4 结构体变量的初始化 5 结构体数组 6 指向结构体类型数据的指针 7 用指针处理链表 8 共用体 9 枚举类型 10 用typedef定义类型 如果插入位置为第一个结点之前(即p1等于head时),则将p0赋给head,将p1赋给p0-next 如果要插到表尾之后,应将p0赋给p1-next,NULL赋给p0-next 如果插入的位置既不在第一个结点之前,又不在表尾结点之后,则将p0的值赋给p2-next,使p2-next指向待插入的结点,然后将p1的值赋给p0-next,使得p0-next指向p1指向的变量。 struct student *insert (struct student *head, struct student *stud) { struct student *p0, *p1, *p2; p1 = head; p0 = stud; if (head == NULL) { head=p0; p0-next=NULL; } else { while ((p0-num p1-num) (p1-next != NULL)) { p2 = p1; p1 = p1-next; } if (p0-num = p1-num) { if (head == p1) head = p0; else p2-next = p0; p0-next = p1; } else { p1-next=p0; p0-next=NULL; } } n++; return (head); } (8)对链表的综合操作 将以上建立、输出、删除、插入的函数组织在一个C程序中,用main函数作主调函数。 void main () { struct student *head, stu; long del_num; printf (intput records:\n); head = creat (); print (head); printf (\nintput the deleted number:\n); scanf (%ld, del_num); head = del (head, del_num); print (head); printf (\nintput the inserted number:\n); scanf (%ld%f, stu.num, stu.score); head = insert (head, stu); print (head); } intput records: 10101 90 10103 98 10105 76 0 0 These 3 records are: 10101 90.0 10103 98.0 10105 76.0 intput the deleted number: 10103 delete:10103 These 2 records are: 10101 90.0 10105 76.0 intput the inserted number: 10102 90 These 3 records are: 10101 90.0 10102 90.0 10105 76.0 此程序运行结果是正确的。它只删除一个结点,插入一个结点。但如果想再插入一个结点,重复写上程序最后4行,共插入两个结点,运行结果却是错误的。 void main () { struct student *head, stu; long del_num; printf (intput records:\n); head = creat (); print (head); printf (\nintput the deleted number:\n); scanf (%ld, del_num); head = del (head, del_num); print (head); printf (\nintput the inserted number:\n); scanf (%ld%f, stu.num, stu.score); head = insert (head, stu); print (head); printf (\nintput the inserted number:\n); scanf (%ld%f, stu.num, stu.sco

文档评论(0)

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

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

1亿VIP精品文档

相关文档