(C语言程序设计11章结构体与共用体.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文档。上传文档
查看更多
(C语言程序设计11章结构体与共用体

要删除链表中的指定结点,首先要查找到链表中待删除的结点,然后将待删除结点的指针域赋值给前一结点的指针域,最后释放被删除结点所占的存储空间。 §11.7.7 在链表中插入一个结点 设有一个链表a1,a2,…,an,现要求在数据元素ai的结点之前插入一个数据元素为x的结点。首先应找到数据元素ai的结点,以便打开ai-1与ai的两数据元素之间的链;然后重新建立ai-1与x、x与ai之间的链,把X结点连入链表中,形成一个新的链表。 算法示意图如下:(此方法的插入顺序是从前往后,只适合于采用姊妹指针进行插入的情况) §11.9 枚举类型 如果一个变量只可能取几个有限的值,这种数据类型叫做“枚举类型”。所谓“枚举”(enumerate)是指将变量的值一一列举出来,变量所能取得的值只限于所列举出来的那些值。 枚举类型的定义: 例如:enum weekday (sun,mon,tue,wed,thu,fri,sat); 上面定义了一个枚举类型enum weekday,可以用此类型来定义枚举类型变量。 比如:enum weekday workday,week_end; 变量workday和week_end被定义为枚举类型,它们的值只能是sun到sat之一。 第十一章 结构体与共用体 小结 §11.1 概述 §11.2 定义结构体类型变量的方法 §11.3 结构体变量的引用 §11.4 结构体变量的初始化 §11.5 结构体数组 §11.6 指向结构体类型数据的指针 §11.7 用指针处理链表 §11.8 共用体 §11.9 用typedef定义类型 #include alloc.h #include string.h main ( ) { char *p ; p = ( char * ) malloc ( 80 * sizeof ( char ) ) ; if ( p = = 0 ) { printf ( “ out of memory \n ” ) ; exit (0) ; } strcpy(p, “BeiJing 2008”); printf(“Olympics: %s”, p); free(p); } 其中,sizeof 是长度运算符,用于测试数据类型的大小。 exit() 函数用于终止当前程序,返回到操作系统。 例题: 请开辟一段能够容纳80个字符的动态内存空间,并在里面存放一个字符串“BeiJing 2008”。 Evaluation only. Created with Aspose.Slides for .NET 3.5 Client Profile . Copyright 2004-2011 Aspose Pty Ltd. §11.7.4 建立一个动态链表 例11.8 编写一个函数实现:建立一个动态链表,链表中的每一个结点保存一个学生的信息(学号、成绩),函数的返回值为该链表的头指针。 #define NULL 0 #define LEN sizeof(struct student) struct student { long num; float score; struct student * next; }; /* 定义一个结构体类型来表示链表结点 */ int n; Evaluation only. Created with Aspose.Slides for .NET 3.5 Client Profile . Copyright 2004-2011 Aspose Pty Ltd. struct student* creat( void ) { struct student* head, *p1, *p2; n=0; p1=p2=(struct student* )malloc(LEN); scanf(“ld,%f”,p1-num,p1-score); head=NULL; while(p1-num!=0) { n=n+1; if(n= =1) head=p1;

文档评论(0)

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

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

1亿VIP精品文档

相关文档