c语言第十章结构体.pptVIP

  1. 1、本文档共41页,可阅读全部内容。
  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文档。上传文档
查看更多
c语言第十章结构体

C语言程序设计 - c语言第8章 结构体 第10章 结构体 内 容 结构体类型定义 结构体变量的定义 结构体变量的引用 结构体变量的初始化 结构数组 结构体和指针 结构体与函数 链表 一、 结构体类型定义 结构体是一种构造数据类型 用途:把不同类型的数据组合成一个整体-------自定义数据类型 结构体类型定义 二、 结构体变量的定义 先定义结构体类型,再定义结构体变量 一般形式:间接定义 三、 结构体变量的引用 引用规则 结构体变量不能整体引用,只能引用变量成员 四、 结构体变量的初始化 间接定义初始化 例:建立一个学生的基本情况表,然后将其打印输出. #includestdio.h #includestring.h struct student{ int num; char name[20]; char sex; int age; float score; }; void main() { struct student stu1,stu2; stu1.num = 10001; strcpy(stu1.name, zhang); stu1.sex = M; stu1.age = 19; stu1.score = 88; stu2 = stu1; 五、 结构体数组 结构体数组的定义 常用形式: 结构体数组初始化 六、 结构体和指针 指向结构体变量的指针 定义形式:struct 结构体名 *结构体指针名; 例 struct student *p; 指向结构体数组的指针 指向结构体自身的成员指针 七、结构体与函数 1、结构体指针做参数 2、结构体变量作参数 3、结构数组作参数 八 链表 动态分配存储 根据需要开辟或释放存储单元 相关函数 malloc函数 calloc函数 free函数 说明 应包含malloc.h或stdlib.h malloc函数 函数原型 typedef unsigned size_t; void *malloc(size_t size); 参数 size:分配存储空间的字节数 返回值 若成功,返回指向分配区域起始地址的指针 若失败,返回NULL free函数 函数原型 void free(void *ptr); 参数 ptr:要释放的内存区地址 说明 释放prt指向的内存区 释放后的内存区能够分配给其他变量使用 结构体的应用—链表 (Link List) 链表的操作 链表的建立 从链尾到链头:新结点插入到链头 从链头到链尾:新结点插入到链尾 链表的遍历 删除结点 根据一定的条件,删除一个或多个结点 插入结点 根据一定的条件,把新结点插入到指定位置 建立链表 (从链尾到链头) 建立链表 (从链头到链尾) 遍历链表 删除结点 插入结点 建立链表 (从链头到链尾) 遍历链表 删除结点 插入结点 链表操作中需要注意的几个问题 注意考虑几个特殊情况下的操作 链表为空表 (head==NULL) 链表只有一个结点 对链表的第一个结点进行操作 对链表的最后一个结点进行操作 最后一个结点的next指针应为NULL 可以定义一个结构体类型用于表示结点的数据部分,以便于对数据的操作 内 容 结构体类型定义 结构体变量的定义 结构体变量的引用 结构体变量的初始化 结构数组 结构体和指针 结构体与函数 链表 例:建立10名学生的信息表,每个学生的数据包括学号、姓名和三门课的成绩。求出每个学生的总分和平均分(用子函数实现),并统计出每门课不及格、一般(60~85)和优秀(85~100)的学生人数(用子函数实现)。 课后作业:p295 五、(2,3,4) ... ai ai+1 ... ④ p-next = q; ② q = malloc(sizeof (struct node));  q-data = x; p ① if(p满足插入条件) q x ③ q-next = p-next; ai-1 ^ ... ④ p-next = q; ② q = malloc(sizeof (struct node));  q-data = a[i]; ① for(i=0; in; i++) ai ^ q ③ q-next = NULL; p ⑤ p = q; ... ai-1 ai ai+1 ... ③ p = p-next; p ① while(p) ② printf(%d, p-data); ... ai-1 ai ai+1 ... ③ p-next = q-next; ④ free(q); ② q = p-next; p q ① if(p-next满足删除条件) ... ai ai+1 ... ④ p-next = q; ② q = ma

您可能关注的文档

文档评论(0)

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

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

1亿VIP精品文档

相关文档