C语言程序设计教程 高等教育计算机类 李树华主编 教学课件28链表 1.pptVIP

C语言程序设计教程 高等教育计算机类 李树华主编 教学课件28链表 1.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文档。上传文档
查看更多
下页 主页 结束 上页 下页 主页 结束 上页 下页 主页 结束 下页 主页 结束 上页 下页 主页 结束 上页 下页 主页 结束 上页 下页 主页 结束 上页 下页 主页 结束 上页 下页 主页 结束 上页 下页 主页 结束 上页 下页 主页 结束 上页 下页 主页 结束 链表 教学目标 应知 了解节点和链表的概念 掌握动态链表的创建和遍历 应会 动态链表的创建 动态链表的遍历 专业英语词汇 英文词汇 对应的中文意义 typedef 类型重命名 list 列表(线性表) linklist 链表 node 节点 malloc 动态申请内存 sizeof 空间大小 回顾与提问 1、如何构建一个静态链表?他有什么作用和不足?怎么使链表更实用? 2、案例3种有哪几个功能,用哪些函数来实现的? 3、检查学生课后实训与作业完成情况(包括小组评价) 演示程序 演示成绩管理案例V3.0模块,察看其中创建链表和遍历的函数。 提问:如何实现对多个学生信息的存储操作? 引出动态链表。 分析与讲解 指向结构体本身的指针 我们可以定义一个指针指向结构体变量,也可以将这个指针定义在某个结构体的内部,作为该结构体的一个成员。 定义形式如下: struct STUDENT { char name[20]; int age; float chinese, math; struct STUDENT *next; //定义了指针next,它可以指向自身结构体类型的变量 }; 利用结构体中包含的这种指针,可以构成一个链表。 分析与讲解 链表的概念 Alice 21 76.5 89.0 Tom 20 81.5 70.5 Bob 22 79.0 79.0 Jerry 21 80.5 88.0 head 为了编程方便,通常头结点空余(不存储信息),只起一个链表起始点的作用。 如上图,链表的最开始一个结点称为头结点。我们通过指向头结点的指针head,就可以访问到链表中的任何结点的信息。 链表的最后一个结点称为尾结点,尾结点的指针必须为空(在C中,用NULL表示 空指针)。 分析与讲解 链表结点成员的访问 当一个链表创建好了之后,我们可以通过指向链表的指针来访问链表中每个结点的成员。 如在上图中,我们想要访问第1个结点的age成员,可以用:   head-next-age 若想访问第2个结点的age成员,可以用:   head-next-next-age 若想访问第3个结点的age成员,可以用:   head-next-next-next-age 分析与讲解 动态开辟和释放空间的函数 编写程序,先动态开辟结构体空间,然后释放它。 #include stdio.h #include stdlib.h struct STUDENT { char name[20]; int age; float chinese, math; struct STUDENT *next; }; main( ) { struct STUDENT *s; s = (struct STUDENT *) malloc(sizeof(struct STUDENT)); gets(s-name); scanf(%d %f %f, s-age, s-chinese, s-math); puts(s-name); printf(%d %f %f, s-age, s-chinese, s-math); free(s); } 分析与讲解 链表的创建 #include stdio.h #include stdlib.h #include string.h struct STUDENT { char name[20]; int age; float chinese, math; struct STUDENT *next; }; //注意:以后所有的结构体操作都使用这个定义 typedef struct STUDENT STU; //给结构体改个别名,可让程序简短 STU *create_list();//声明创建链表函数 void print_list(STU *head); //声明输出链表函数 main() { STU *head; head = create_list(); //调用函数,创建链表 print_list(head); //输出以head为头指针的链表 } 分析与讲解 创建函数--create_list()

您可能关注的文档

文档评论(0)

时间加速器 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档