清华大学C语言课件第9章_用户建立的数据类型幻灯片.ppt

清华大学C语言课件第9章_用户建立的数据类型幻灯片.ppt

  1. 1、本文档共76页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
11.8 共用体 void main() {int i; for(i=0;i2;i++) {scanf(%d %s %c %c, person[i].num, person[i].name, person[i].sex, person[i].job); if(person[i].job == S) scanf(%d, person[i].category.banji); else if(person[i].job == T) scanf(%s, person[i].category.position); else printf(“Input error!”);} printf(\n); printf(No. name sex job class/position\n); for(i=0;i2;i++) {if (person[i].job == S) printf(“%-6d%-10s%-3c%-3c%-6d\n”,person[i].num, person[i].name, person[i].sex, person[i].job, person[i].category.banji); else printf(“%-6d%-10s%-3c%-3c%-6s\n”,person[i].num, person[i].name,person[i].sex, person[i].job, person[i].category.position);}} 运行情况如下: 101 Li f s 501 Wang m t professor   No. Name sex jobclass/position 101  Li   f s  501 102  Wang m t professor 9.5 共用体类型 也可以不在结构体类型的声明中声明共用体类型, 而把它放在结构体类型的声明之前,即: {int i; union categ { int banji; char position[10]; }; struct { int num; char name[10]; char sex; char job; union categ category;}person[2]; §9.6 枚举类型 枚举:将变量的值一一列举出来,变量的值只限于列举 出来的值的范围内。 申明枚举类型用enum enum weekday{sun,mon,tue,wed,thu,fri,sat};  定义变量: enum weekday workday,week-day; enum{sun,mon,tue,wed,thu,fri,sat}workday; 变量值只能是sun到sat之一 枚举元素 枚举常量 §9.6 枚举类型 说明: 在C编译中,对枚举元素按常量处理,故称枚举 常量。它们不是变量,不能对它们赋值。 (2) 枚举元素作为常量,它们是有值的,C语言编译 按定义时的顺序使它们的值为0,1,2… (3) 枚举值可以用来作判断比较。 (4) 一个整数不能直接赋给一个枚举变量。 §9.6 枚举类型 例11.13口袋中有红、黄、蓝、白、黑5种颜色的球若干 个。每次从口袋中先后取出3个球,问得到3种不同色的球 的可能取法,输出每种排列的情况。 算法: 图9-22 9-23 §13.9 枚举类型 #include stdio.h main() {enum color {red,yellow,blue,white,black}; enum color i,j,k,pri; int n,loop;n=0; for (i=red;i=black;i++) for (j=red;j=black;j++) if (i!=j) { for (k=red;k=black;k++) if ((k!=i) (k!=j)) {n=n+1; printf(%-4d,n); for (loop=1;loop=3;loop++) { switch (loop) { case 1: pri=i;break; case 2: pri=j;break;

您可能关注的文档

文档评论(0)

带头大哥 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档