- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第13讲指向结构体的指针与链表(C语言)
第十三讲 指向结构体的指针与链表
??? 本讲首先介绍了C语言中指向结构体变量和结构体数组的指针变量的使用,接着介绍了结构体数据作为函数参数的使用,最后介绍了链表的概念和基本操作。要求大家掌握指向结构体变量的指针变量和指向结构体数组及数组元素的指针变量的定义和引用,理解指向结构体变量的指针变量、结构体变量及其成员作为函数参数的使用方法,掌握链表中结点的描述方式,了解链表的建立、输出、插入和删除操作。
??? 知识要点
指向结构体变量的指针变量1. 指向结构体变量的指针变量的定义2. 利用指向结构体变量的指针变量对结构体变量成员的引用
指向结构体数组的指针变量1. 指向结构体数组的指针变量的使用
结构体数据作函数参数1. 结构体变量的成员作函数参数2. 结构体变量作函数参数3. 指向结构体的指针作函数参数
链表的概念1. 链表的组成2. 结点用结构体类型描述3. 动态申请和释放内存单元的函数
链表的操作1. 建立链表2. 在链表中插入结点3. 删除链表中的结点
§13.1 指向结构体变量的指针变量
??? 指向结构体变量的指针变量的定义形式与一般指针变量的定义形式相同,只是将其指向类型定义为结构体类型即可。例如:??????? struct person??????????? { char name[20];????????????? char sex;????????????? int age;????????????? float height;??????????? };?????? struct person *p;则指针变量p,它可以指向struct person类型的结构体变量。
??? 将一个指针变量指向一个结构体变量后,可以利用指向该结构体的的指针变量引用成员,如:??????? (* 指针变量名).成员名以上形式也常写成:??????? 指针变量名-成员名其中,-为指向运算符,它是由符号“-”和“”两部分构成的。指向运算符的优先级和成员运算符相同,也是最高一级。
§13.2 指向结构体数组的指针变量
??? 指针变量可以指向整型、字符型、浮点型等基本类型数组。同样,指针变量也可以指向结构体类型的数组。
??? 程序L13_2.C功能:使用指向结构体数组的指针变量。
#include stdio.hvoid main(){ struct person{ char name[20];char sex;int age;float height;}per[3]={{ Li Ping, M ,20,175},{Wang Ling, F ,19,162.5},{Zhao Hui, M ,20,178}};struct person *p;for (p=per;pper+3;p++)printf(%–18s%3c%4d%7.1f\n , p-name, p-sex, p-age, p-height);}
§13.3 结构体数据作函数参数
??? 不仅结构体变量的成员可以作函数参数,结构体变量以及指向结构体变量的指针都可以作函数参数。
??? 一、结构体变量的成员作函数参数
??? 结构体变量的成员作实参与简单变量、数组元素等作实参是一样的。
??? 二、结构体变量作函数参数
??? C允许将整个结构体变量作为函数参数传递。传递的是结构体变量全部成员的值,将实参中成员的值赋给对应的形参成员。
??? 用结构体变量作实参时,由于要为形参结构体变量分配存储空间,还要一一对应传递各成员的值,这样会增加处理的时间同时也浪费了内存空间,从而影响程序的运行效率。
??? 三、指向结构体的指针作函数参数
??? 使用指向结构体的指针作函数实参,形参也必须是一个指向相同结构体类型的指针变量,其它使用方法不变。
§13.4 链表的概念
??? 链表是动态数据结构中最基本的形式,它的规模大小可以根据需要进行动态变化,达到合理地使用存储空间。
??? 链表有一个“头指针”变量,用来指向链表的第一个元素。链表中的每个元素都称为“结点”,结点包含两部分内容:一是实际的数据信息;二是下一结点的指针,。链表的最后一个元素置为“NULL”(空地址),标志链表结束。
??? 一个结点可以用一个结构体类型来描述。结构体中包含若干成员,用来表示结点的数据信息。此外必须有一个成员是与结点类型一致的指针,用来指向后续结点。例如,一个链表的结点可以定义为以下的结构体类型:??????? struct node??????????? { int data1;????????????? float data2;????????????? str
文档评论(0)