- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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()
您可能关注的文档
- C语言程序设计 高职计算机大类专业 徐永青任务4 简单构造数据类型的应用.ppt
- C语言程序设计 高职计算机大类专业 徐永青任务5 模块化程序设计.ppt
- 机械制造基础 第二版 3 5章答案与6章填空答案.doc
- C语言程序设计 高职计算机大类专业 徐永青任务7 文件函数的使用.ppt
- 机械制造基础 第二版 第1 2 4章填空答案.doc
- 李镜管理学基础 李镜 习题第二套.doc
- C语言程序设计 高职计算机大类专业 徐永青任务8 综合项目设计.ppt
- 李镜管理学基础 李镜 习题第三套.doc
- 李镜管理学基础 李镜 习题第四套.doc
- 李镜管理学基础 李镜 习题第五套.doc
- 汽油发动机微机控制系统检修 任务单2.9任务单.doc
- C语言程序设计教程 高等教育计算机类 李树华主编 教学课件29链表 2.ppt
- C语言程序设计教程 高等教育计算机类 李树华主编 教学课件30链表与文件.ppt
- C语言简明教程 第二版 高职计算机大类专业 李忠儒 郭晓利第1章 概述.ppt
- C语言简明教程 第二版 高职计算机大类专业 李忠儒 郭晓利第2章 数据类型 运算符及表达式.ppt
- C语言简明教程 第二版 高职计算机大类专业 李忠儒 郭晓利第3章 顺序结构程序设计.ppt
- C语言简明教程 第二版 高职计算机大类专业 李忠儒 郭晓利第4章 选择结构程序设计.ppt
- C语言简明教程 第二版 高职计算机大类专业 李忠儒 郭晓利第5章 循环结构程序设计.ppt
- C语言简明教程 第二版 高职计算机大类专业 李忠儒 郭晓利第6章 数组与字符串.ppt
- 汽油发动机微机控制系统检修课后习题答案.doc
最近下载
- 2025至2030年中国报废汽车回收拆解行业市场运行现状及投资规划建议报告.docx
- Unit 2 What do you like about your family Period 1 Ready Go & Sound 教学设计 沪教版(2025)二年级英语上册.docx VIP
- 食品添加剂 甲醇钠标准2023年.docx VIP
- 高一语文上学期《乡土中国》-差序格局教学课件.pptx VIP
- 企业安全生产检查标准化表格.doc VIP
- 中成药的临床合理应用试卷含答案.docx
- 《HIV病毒与艾滋病》课件.ppt VIP
- 第二单元第1课《因地制宜》课件-2025-2026学年人教版(2024)八年级上册.pptx VIP
- 高标准农田建设标准NYT2148-2012.pdf VIP
- 世界少年奥林匹克数学竞赛(中国区)选拔赛省级选拔模拟卷(三)三年级试题(含解析)2025年5月夏季.docx VIP
原创力文档


文档评论(0)