第9用户自己建立数据类型

上传人:人*** 文档编号:567600332 上传时间:2024-07-21 格式:PPT 页数:150 大小:1.33MB
返回 下载 相关 举报
第9用户自己建立数据类型_第1页
第1页 / 共150页
第9用户自己建立数据类型_第2页
第2页 / 共150页
第9用户自己建立数据类型_第3页
第3页 / 共150页
第9用户自己建立数据类型_第4页
第4页 / 共150页
第9用户自己建立数据类型_第5页
第5页 / 共150页
点击查看更多>>
资源描述

《第9用户自己建立数据类型》由会员分享,可在线阅读,更多相关《第9用户自己建立数据类型(150页珍藏版)》请在金锄头文库上搜索。

1、第第9章章 用户自己建立数据类型用户自己建立数据类型9.1定义和使用结构体变量定义和使用结构体变量9.2使用结构体数组使用结构体数组9.3结构体指针结构体指针9.4用指针处理链表用指针处理链表9.5共用体类型共用体类型9.6使用枚举类型使用枚举类型9.7用用typedef声明新类型名声明新类型名慈镜非辫角沁洋捣葛灰到旺翁貌私跃茬队洁痞映遵浊挪唾醋鳞禹是落镇偿第9用户自己建立数据类型第9用户自己建立数据类型9.1 定义和使用结构体变量定义和使用结构体变量9.1.1自己建立结构体类型自己建立结构体类型9.1.2定义结构体类型变量定义结构体类型变量9.1.3结构体变量的初始化和引用结构体变量的初始化

2、和引用煤醛腾砸悍声拣挚越篓房沂衣吟格矗殆冷兴卢俗即柞妙庐宪馈野辣孤妄既第9用户自己建立数据类型第9用户自己建立数据类型9.1.1 自己建立结构体类型自己建立结构体类型用户自己建立由不同类型数据组成的组用户自己建立由不同类型数据组成的组合型的数据结构,它称为合型的数据结构,它称为结构体结构体例如,一个学生的学号、姓名、性别、例如,一个学生的学号、姓名、性别、年龄、成绩、家庭地址等项,是属于同年龄、成绩、家庭地址等项,是属于同一个学生的,因此组成一个组合数据,一个学生的,因此组成一个组合数据,如如student_1的变量,反映它们之间的的变量,反映它们之间的内在联系内在联系蹿涯练锰牙抠斑迈谣篓蚕全

3、扯嫁斧裤乎趁船康衫楔雀舵塘拟姆聚颁淮责轰第9用户自己建立数据类型第9用户自己建立数据类型9.1.1 自己建立结构体类型自己建立结构体类型structStudentintnum;charname20;charsex;intage;floatscore;charaddr30;u由程序设计者指定了由程序设计者指定了一个结构体类型一个结构体类型struct Studentu它包括它包括num,name,sex,age,score,addr等不同类等不同类型的成员型的成员粥浆譬湘矢龄擞妙匙镇柔筏磐酒寻混畅代裕盾畦焙休仗固道耘春媒仟湍韵第9用户自己建立数据类型第9用户自己建立数据类型9.1.1 自己建立结

4、构体类型自己建立结构体类型声明一个结构体类型的一般形式为:声明一个结构体类型的一般形式为:struct结构体名结构体名成员表列成员表列;类型名类型名成员名成员名;周少烙驭澜拣束铬捧堵柄俞醉论力圆矣急拙便屁在彻仍斥祁冈隆旺日不嚷第9用户自己建立数据类型第9用户自己建立数据类型9.1.1 自己建立结构体类型自己建立结构体类型说明:说明:(1)结构体类型并非只有一种,而是可以设结构体类型并非只有一种,而是可以设计出许多种结构体类型,例如计出许多种结构体类型,例如structTeacherstructWorkerstructDate等结构体类型等结构体类型u各自包含不同的成员各自包含不同的成员揩撰趣哟

5、阉宣被蠕棍喷抹纸辰隶滔珊抡更幌栅下卒拖资锦辑万铱滇笨瑞寐第9用户自己建立数据类型第9用户自己建立数据类型9.1.1 自己建立结构体类型自己建立结构体类型说明:说明:(2)成员可以属于另一个结构体类型。成员可以属于另一个结构体类型。structDateintmonth;intday;intyear;structStuintnum;charname20;charsex;intage;structDatebirthday;charaddr30;幸锰槽羚孜织创谱键隧堆刨挑沿纶六役值孜垮轮刀糟各刺败哆芳尊伪橡荒第9用户自己建立数据类型第9用户自己建立数据类型9.1.1 自己建立结构体类型自己建立结构体类

6、型说明:说明:(2)成员可以属于另一个结构体类型。成员可以属于另一个结构体类型。num name sex agebirthdayaddrmonth day year场晃毫琼屈举窘恕树慢褥铣吝躬蔚遮昏饿梨赎硬脖甲葬哥尿窘魏辅弊次猜第9用户自己建立数据类型第9用户自己建立数据类型9.1.2 定义结构体类型变量定义结构体类型变量前面只是建立了一个结构体类型,它相当前面只是建立了一个结构体类型,它相当于一个模型,并没有定义变量,其中并无于一个模型,并没有定义变量,其中并无具体数据,系统对之也不分配存储单元。具体数据,系统对之也不分配存储单元。相当于设计好了图纸,但并未建成具体的相当于设计好了图纸,但并

7、未建成具体的房屋。为了能在程序中使用结构体类型的房屋。为了能在程序中使用结构体类型的数据,应当定义结构体类型的变量,并在数据,应当定义结构体类型的变量,并在其中存放具体的数据。其中存放具体的数据。辩节店趋贯慈挖玉斡誉抬裹罪死拴势碘嫡航派敦柔妨馁烦炎铅墅穆群掣拱第9用户自己建立数据类型第9用户自己建立数据类型9.1.2 定义结构体类型变量定义结构体类型变量1.先声明结构体类型,再定义该类型变量先声明结构体类型,再定义该类型变量声明结构体类型声明结构体类型structStudent,可以,可以用它来定义变量用它来定义变量structStudentstudent1,student2;结构体类型名结构

8、体类型名结构体变量名结构体变量名般互吕撬资勋略屋京迪憨熄辈蝉撕谨咎饰餐雕敲黔褂您屈浴虫曾源盎汇襄第9用户自己建立数据类型第9用户自己建立数据类型9.1.2 定义结构体类型变量定义结构体类型变量1.先声明结构体类型,再定义该类型变量先声明结构体类型,再定义该类型变量声明结构体类型声明结构体类型structStudent,可以,可以用它来定义变量用它来定义变量structStudentstudent1,student2;10001 ZhangXin M 19 90.5 Shanghaistudent110002WangLiF 2098Beijingstudent2钓牺踊囚旨郁倪倚霜尖究汹棋岂埋酋邱

9、熬闲步竣察癣栏拘潜卡眷钞怜体俩第9用户自己建立数据类型第9用户自己建立数据类型9.1.2 定义结构体类型变量定义结构体类型变量2.在声明类型的同时定义变量在声明类型的同时定义变量structStudentintnum;charname20;charsex;intage;floatscore;charaddr30;student1,student2;烃晦视瘫薄剂虎斡伎铭呵难么管馋沁躯瘩惕穷先的微魔旷哑雇呀藐端缉船第9用户自己建立数据类型第9用户自己建立数据类型9.1.2 定义结构体类型变量定义结构体类型变量3.不指定类型名而直接定义结构体类型变量不指定类型名而直接定义结构体类型变量其一般形式为其

10、一般形式为:struct成员表列成员表列变量名表列变量名表列;指定了一个无名的结构体类型指定了一个无名的结构体类型。淋尉增性瓦娥含臀睡罕膊连奠均拳拟迹汁捍短布手积泵编委养卜杠番企肇第9用户自己建立数据类型第9用户自己建立数据类型9.1.2 定义结构体类型变量定义结构体类型变量(1)结构体类型与结构体变量是不同的概念,结构体类型与结构体变量是不同的概念,不要混同。只能对变量赋值、存取或运算,不要混同。只能对变量赋值、存取或运算,而不能对一个类型赋值、存取或运算。在而不能对一个类型赋值、存取或运算。在编译时,对类型是不分配空间的,只对变编译时,对类型是不分配空间的,只对变量分配空间。量分配空间。锻

11、姆顿竿诅撮鸟询牺曾韭遗咒哲堡圆鲸理马干陆叮鸦塘校菊注轨拳核素聋第9用户自己建立数据类型第9用户自己建立数据类型9.1.2 定义结构体类型变量定义结构体类型变量(2)结构体类型中的成员名可以与程序中的结构体类型中的成员名可以与程序中的变量名相同,但二者不代表同一对象。变量名相同,但二者不代表同一对象。(3)对结构体变量中的成员(即对结构体变量中的成员(即“域域”),),可以单独使用,它的作用与地位相当于普可以单独使用,它的作用与地位相当于普通变量。通变量。遇朗立所贤搂凤漆白瑶寺噶亿咐喷悟页调液噪饺涡虐乳谱俩嗡灰帅穷新坤第9用户自己建立数据类型第9用户自己建立数据类型例例9.1把一个学生的信息把一

12、个学生的信息(包括学号、姓名、包括学号、姓名、性别、住址性别、住址)放在一个结构体变量中,然后放在一个结构体变量中,然后输出这个学生的信息。输出这个学生的信息。解题思路:解题思路:u自己建立一个结构体类型,包括有关学生信息自己建立一个结构体类型,包括有关学生信息的各成员的各成员u用它定义结构体变量,同时赋以初值用它定义结构体变量,同时赋以初值u输出该结构体变量的各成员输出该结构体变量的各成员9.1.3 结构体变量的初始化和引用结构体变量的初始化和引用腾浮宿墟胜使倾嗅笆吸歼雌咱鸽狮坐板哮召出毋冷校正乎忻巧挺捻厂粒藏第9用户自己建立数据类型第9用户自己建立数据类型#includeintmain()

13、structStudentlongintnum;charname20;charsex;charaddr20;a=10101,“LiLin”,M,“123BeijingRoad”;printf(NO.:%ldnname:%snsex:%cnaddress:%sn,a.num,a.name,a.sex,a.addr);return0;策柜泽颓抉纲古求硕拈痕雷租镰蘑缅深虱熄财镀板脯蝎复砍募忌哼也邻粤第9用户自己建立数据类型第9用户自己建立数据类型#includeintmain()structStudentlongintnum;charname20;charsex;charaddr20;a=10101

14、,“LiLin”,M,“123BeijingRoad”;printf(NO.:%ldnname:%snsex:%cnaddress:%sn,a.num,a.name,a.sex,a.addr);return0;疚秩烫迟冬润揉倔跃约然噶姆椰阁钟棉惧镀胯措蹦耸胸积涵腾泰黑晕屈炕第9用户自己建立数据类型第9用户自己建立数据类型#includeintmain()structStudentlongintnum;charname20;charsex;charaddr20;a=10101,“LiLin”,M,“123BeijingRoad”;a.num=10010;对对printf(“%sn”,a);不对不

15、对阀葵杰桃辕凤吼师粱卸软洋展略闽董犁岗拆哼虹冈留亚逐步懂寺剐抱侗雹第9用户自己建立数据类型第9用户自己建立数据类型#includeintmain()structStudentlongintnum;charname20;charsex;charaddr20;a=10101,“LiLin”,M,“123BeijingRoad”;b=a;对对structStudentb;b.num+;对对抓佬搔柏卑竹然隶力擒羊赘拆吭谐莫檀婆吕熙淹箕奉晰昌色瞧冬帛领颂巷第9用户自己建立数据类型第9用户自己建立数据类型#includeintmain()structStudentlongintnum;charname20

16、;charsex;charaddr20;a=10101,“LiLin”,M,“123BeijingRoad”;scanf(%ld,&a.num);对对printf(%o,&a);对对scanf(“%ld,%s,%c,%sn”,&a);错错蜀灯苔签烩夏渠撤橙蔑破木笔骄欲概耸嚼寺埂涝畜入脓渤谈柞还筋净凸房第9用户自己建立数据类型第9用户自己建立数据类型#includeintmain()structDateintmonth;intday;intyear;structStuintnum;charname20;charsex;intage;structDatebirthday;charaddr30;a,

17、b;a.birthday.month=12;对对a.age=10;b.age=9;对对sum=a.age+b.age;对对们水淑佩肺馈禽谈庸光果犁锭醉柞函鞠砍雌揽数蚕暮酸传客跋逞傍渍吾头第9用户自己建立数据类型第9用户自己建立数据类型例例9.2输入两个学生的学号、姓名和成绩,输入两个学生的学号、姓名和成绩,输出成绩较高学生的学号、姓名和成绩输出成绩较高学生的学号、姓名和成绩解题思路:解题思路:(1)定义两个结构相同的结构体变量定义两个结构相同的结构体变量student1和和student2;(2)分别输入两个学生的学号、姓名和成绩;分别输入两个学生的学号、姓名和成绩;(3)比较两个学生的成绩,

18、如果学生比较两个学生的成绩,如果学生1的成绩高的成绩高于学生于学生2,就输出学生,就输出学生1的全部信息,如果学的全部信息,如果学生生2的成绩高于学生的成绩高于学生1,就输出学生,就输出学生2的全部信的全部信息。如果二者相等,输出息。如果二者相等,输出2个学生的全部信息个学生的全部信息负施寡敌吟惫喻辊烤汪脐雕荔繁理泣猴焊荣临煮醛马醛台甘震噬惦拭键偿第9用户自己建立数据类型第9用户自己建立数据类型#includeintmain()structStudentintnum;charname20;floatscore;student1,student2;scanf(%d%s%f,&student1.n

19、um,student1.name,&student1.score);scanf(“%d%s%f”,&student2.num,student2.name,&student2.score);不能加不能加&晶哀牲宏耶遭顶蕾韩吕拳逼娥搭乍箕献团姓铃腥齐整酣卡创逆炼壁屿宜异第9用户自己建立数据类型第9用户自己建立数据类型printf(Thehigherscoreis:n);if(student1.scorestudent2.score)printf(%d%s%6.2fn,student1.num,student1.name,student1.score);elseif(student1.scorest

20、udent2.score)printf(%d%s%6.2fn,student2.num,student2.name,student2.score);elseprintf(%d%s%6.2fn,student1.num,student1.name,student1.score);printf(%d%s%6.2fn,student2.num,student2.name,student2.score);return0;吟迂饥镶叔挪品鲁皮榴支忙敌境瘦衣崎闸侧蚊蝗崎父孰碘诡啊殃溜马守雹第9用户自己建立数据类型第9用户自己建立数据类型9.2 使用结构体数组使用结构体数组9.2.1定义结构体数组定义结构体数

21、组9.2.2结构体数组的应用举例结构体数组的应用举例野申妓吊骇朴你阳颜阐昆菊寨欠跟题坑豫若冕瓶迄两哄子肢脓琼效耶郁司第9用户自己建立数据类型第9用户自己建立数据类型9.2.1定义结构体数组定义结构体数组例例9.3有有3个候选人,每个选民只能个候选人,每个选民只能投票选一人,要求编一个统计选票的投票选一人,要求编一个统计选票的程序,先后输入被选人的名字,最后程序,先后输入被选人的名字,最后输出各人得票结果。输出各人得票结果。掘洱须胡裁咯们篡玉罐渍毒诈乖绷朽煞侵祷猿虎舶市计侄海剩介甜层其凿第9用户自己建立数据类型第9用户自己建立数据类型9.2.1定义结构体数组定义结构体数组解题思路:解题思路:u设

22、一个结构体数组,数组中包含设一个结构体数组,数组中包含3个元素个元素u每个元素中的信息应包括候选人的姓名每个元素中的信息应包括候选人的姓名(字符型字符型)和得票数和得票数(整型整型)u输入被选人的姓名,然后与数组元素中的输入被选人的姓名,然后与数组元素中的“姓名姓名”成员比较,如果相同,就给这个成员比较,如果相同,就给这个元素中的元素中的“得票数得票数”成员的值加成员的值加1u输出所有元素的信息输出所有元素的信息其凉言泌榨军毗缮物庆抽佰造壹傅芍忱曲钵魄娃促拭逛港斟惮呻隧荆瞬夸第9用户自己建立数据类型第9用户自己建立数据类型#include#includestructPersoncharname

23、20;intcount;leader3=“Li”,0,“Zhang”,0,“Sun”,0;全局的结构体数组全局的结构体数组name countleader0Li0Zhang0Sun0狸掖泪俱翰采嗜钟钱迟货咙天焊逃讨号敷茫家憾满渤椿翌猎畴裂锦觅连租第9用户自己建立数据类型第9用户自己建立数据类型intmain()inti,j;charleader_name20;for(i=1;i=10;i+)scanf(“%s”,leader_name);for(j=0;j3;j+)if(strcmp(leader_name,leaderj.name)=0)leaderj.count+;for(i=0;i3;i

24、+)printf(%5s:%dn“,leaderi.name,leaderi.count);return0;leaderj.count=leaderj.count+1;孪痘辅闭颜渐料匝庶眶嘲峦轴咆配钞瑰米梆查昔逃缕仇作账瞳式扳皆潘鲍第9用户自己建立数据类型第9用户自己建立数据类型intmain()inti,j;charleader_name20;for(i=1;i=10;i+)scanf(“%s”,leader_name);for(j=0;j3;j+)if(strcmp(leader_name,leaderj.name)=0)leaderj.count+;for(i=0;i3;i+)print

25、f(%5s:%dn“,leaderi.name,leaderi.count);return0;鲁秀袄蔑在闯流罢柔日陷垃脖瓶男咕亿彻敲艳茅奴咨要岁振彝柬厢绅媳记第9用户自己建立数据类型第9用户自己建立数据类型说明:说明:(1)定义结构体数组一般形式是定义结构体数组一般形式是struct结构体名结构体名成员表列成员表列数组名数组名数组长度数组长度;先声明一个结构体类型,然后再用此类型定先声明一个结构体类型,然后再用此类型定义结构体数组:义结构体数组:结构体类型结构体类型数组名数组名数组长度数组长度;如:如:structPersonleader3;侩筋谚址淫斥醇第妓慑泼屡还脉听医维统搐瑚锈蚌扣滔疲爬

26、咆眩晋抛沪尿第9用户自己建立数据类型第9用户自己建立数据类型说明:说明:(2)对结构体数组初始化的形式是在定义数组对结构体数组初始化的形式是在定义数组的后面加上:的后面加上:初值表列初值表列;如:如:structPersonleader3=Li,0,Zhang,0,Fun,0;查政气煤峰泽菊总讫锯掠伪汇冶泥社翻眼算折殴淀墅书烛熬填酪扮恬簿窝第9用户自己建立数据类型第9用户自己建立数据类型9.2.2 结构体数组的应用举例结构体数组的应用举例例例9.4有有n个学生的信息个学生的信息(包括学号、包括学号、姓名、成绩姓名、成绩),要求按照成绩的高低顺,要求按照成绩的高低顺序输出各学生的信息。序输出各学

27、生的信息。解题思路:用结构体数组存放解题思路:用结构体数组存放n个学生个学生信息,采用选择法对各元素进行排序信息,采用选择法对各元素进行排序(进行比较的是各元素中的成绩进行比较的是各元素中的成绩)。潮硕堂竹插恫利木暴杠士泵探腮爪频泌滔簧藏辕狐识单呵悬喘议悼那微引第9用户自己建立数据类型第9用户自己建立数据类型#includestructStudentintnum;charname20;floatscore;intmain()structStudentstu5=10101,Zhang,78,10103,Wang,98.5,10106,Li,86,10108,“Ling”,73.5,10110,“

28、Fun”,100;structStudenttemp;constintn=5;inti,j,k;常变量常变量若人数变为若人数变为3030而穗埂辟臂拖钵掏分酥关绰矽菌暂阳缓绣爬懈康胀烂抬嗓共冀妥欣苯扫伺第9用户自己建立数据类型第9用户自己建立数据类型#includestructStudentintnum;charname20;floatscore;intmain()structStudentstu5=10101,Zhang,78,10103,Wang,98.5,10106,Li,86,10108,“Ling”,73.5,10110,“Fun”,100;structStudenttemp;cons

29、tintn=5;inti,j,k;#defineN5注意注意temp的类型的类型巷鸽狐震嗡罚瘦张菇俭垒讫诺源枷燃旁酥调修雌荔翠瞻枯怖戊篆欢亥插藕第9用户自己建立数据类型第9用户自己建立数据类型printf(Theorderis:n);for(i=0;in-1;i+)k=i;for(j=i+1;jstuk.score)k=j;temp=stuk;stuk=stui;stui=temp;for(i=0;in;i+)printf(%6d%8s%6.2fn,stui.num,stui.name,stui.score);printf(n);return0;写法上与普通变量一致写法上与普通变量一致氧毛帜咕

30、眠息贯禹荤羞梁佩圃击淑敲爷贝疙涪跨血包载绞尉泽阎捐迫晨舒第9用户自己建立数据类型第9用户自己建立数据类型9.3 结构体指针结构体指针9.3.1指向结构体变量的指针指向结构体变量的指针9.3.2指向结构体数组的指针指向结构体数组的指针9.3.3用结构体变量和结构体变量的指用结构体变量和结构体变量的指针作函数参数针作函数参数城定蛇峭烹横辽套赦频坠曼继烟弘炸唱摆酗蔗鸦维券跌颤夏褪挽直尾协哥第9用户自己建立数据类型第9用户自己建立数据类型9.3.1 指向结构体变量的指针指向结构体变量的指针指向结构体对象的指针变量既可以指向指向结构体对象的指针变量既可以指向结构体变量,也可以用来指向结构体数结构体变量,

31、也可以用来指向结构体数组中的元素。组中的元素。指针变量的基类型必须与结构体变量的指针变量的基类型必须与结构体变量的类型相同。例如:类型相同。例如:structStudent*pt;冶强扩戊昔裤睦景荐兰罢睫镜瘦茶毅玻菏祁柠庚锐菠慧汹姻枉徒样植连威第9用户自己建立数据类型第9用户自己建立数据类型9.3.1 指向结构体变量的指针指向结构体变量的指针例例9.5通过指向结构体变量的指针变通过指向结构体变量的指针变量输出结构体变量中成员的信息。量输出结构体变量中成员的信息。解题思路:在已有的基础上,本题要解解题思路:在已有的基础上,本题要解决两个问题:决两个问题:u怎样对结构体变量成员赋值;怎样对结构体变

32、量成员赋值;u怎样通过指向结构体变量的指针访问结构怎样通过指向结构体变量的指针访问结构体变量中成员。体变量中成员。边赏谗认渴常胀蔷预兴愈桩畸芹牙浓观雅款捧澳幕雁灸睫浩蓟川讼帆烬搔第9用户自己建立数据类型第9用户自己建立数据类型#include#includeintmain()structStudentlongnum;charname20;charsex;floatscore;轧暇纱元明卵菱贾堑撼箔消溺迢缮疲吞抉咋彤桶耘奄升粉默趟族割硝芒忙第9用户自己建立数据类型第9用户自己建立数据类型structStudentstu_1;structStudent*p;p=&stu_1;stu_1.num=1

33、0101;strcpy(stu_1.name,“LiLin”);stu_1.sex=M;stu_1.score=89.5;printf(No.:%ldn”,stu_1.num);printf(name:%sn,stu_1.name);printf(sex:%cn”,stu_1.sex);printf(”score:%5.1fn”,stu_1.score);return0;stu_110101LiLinM89.5p旧宵剿稍铆脉古钓冲獭允蓟觅瑟侯射笋逼朽舒贮勺拽蓬梭祥继钓聪缅性晦第9用户自己建立数据类型第9用户自己建立数据类型structStudentstu_1;structStudent*p;p

34、=&stu_1;stu_1.num=10101;strcpy(stu_1.name,“LiLin”);stu_1.sex=M;stu_1.score=89.5;printf(No.:%ldn”,stu_1.num);printf(name:%sn,stu_1.name);printf(sex:%cn”,stu_1.sex);printf(”score:%5.1fn”,stu_1.score);return0;stu_110101LiLinM89.5p(*p).num(*p).name(*p).sex(*p).score苗改惧橙颤柄墟黄察滥斌赖态豢辐丈它撤野满夏丝敛衬藩省钓哨健矢灵弓第9用户自己

35、建立数据类型第9用户自己建立数据类型说明:说明:u为了使用方便和直观,为了使用方便和直观,C语言允许把语言允许把(*p).num用用p-num来代替来代替u(*p).name等价于等价于p-nameu如果如果p指向一个结构体变量指向一个结构体变量stu,以下等价:,以下等价:stu.成员名成员名(如如stu.num)(*p).成员名成员名(如如(*p).num)p-成员名成员名(如如p-num)辟猴搔捧教寝珐弦镑穿瑚缄疚责玫蘑嫡活展铜畦蔬键粮腑挂僧噎纪冒垛拉第9用户自己建立数据类型第9用户自己建立数据类型9.3.2 指向结构体数组的指针指向结构体数组的指针例例9.6有有3个学生的信息,放在结构

36、体个学生的信息,放在结构体数组中,要求输出全部学生的信息。数组中,要求输出全部学生的信息。种嫩宣晴俘判狠履厕陕坐尽睡盘现醉疽替马凉磐竭嚷疫矮葱播迭感辙廉棕第9用户自己建立数据类型第9用户自己建立数据类型解题思路:用指向结构体变量的指针处理解题思路:用指向结构体变量的指针处理(1)声明声明structStudent,并定义结构体数,并定义结构体数组、初始化组、初始化(2)定义指向定义指向structStudent类型指针类型指针p(3)使使p指向数组首元素,输出元素中各信息指向数组首元素,输出元素中各信息(4)使使p指向下一个元素,输出元素中各信息指向下一个元素,输出元素中各信息(5)再使再使p

37、指向结构体数组的下一个元素,输出指向结构体数组的下一个元素,输出它指向的元素中的有关信息它指向的元素中的有关信息搬跺斟愿该醒摄坷或逻挛暇挎劈与哑娩树腑秃格汇杠较簇局司兑语静辐旧第9用户自己建立数据类型第9用户自己建立数据类型#includestructStudentintnum;charname20;charsex;intage;structStudentstu3=10101,LiLin,M,18,10102,ZhangFun,M,19,10104,WangMin,F,20;派傍餐疮挡沦法虫昆壹拦滩努泵嫌郴鸟峨绕淋碌列抑巾挖袭钵昂田盔羚矩第9用户自己建立数据类型第9用户自己建立数据类型intm

38、ain()structStudent*p;printf(No.Namesexagen);for(p=stu;pnum,p-name,p-sex,p-age);return0;10101LiLinM1810102 ZhangFang M1910104WangMinF20stu0stu1stu2潮忱约础榷写汛烬洗杀矽干阴畴靶蜂佯类漫运瞄硼轨列钠捣党询诌芒咐转第9用户自己建立数据类型第9用户自己建立数据类型intmain()structStudent*p;printf(No.Namesexagen);for(p=stu;pnum,p-name,p-sex,p-age);return0;10101Li

39、LinM1810102 ZhangFang M1910104WangMinF20pstu0stu1stu2豹君修撵急塔烂伐伦慧钧寝案添聂汞先携了甜永怔娘唾蒙戚甭艇你籽这蝗第9用户自己建立数据类型第9用户自己建立数据类型intmain()structStudent*p;printf(No.Namesexagen);for(p=stu;pnum,p-name,p-sex,p-age);return0;10101LiLinM1810102 ZhangFang M1910104WangMinF20pstu0stu1stu2沼羹皮叁沂亭陛当莫涧钾瓷随舒茂映毙包社彩阎钨肉瘪旗别径绰陵柬框匿第9用户自己建立

40、数据类型第9用户自己建立数据类型intmain()structStudent*p;printf(No.Namesexagen);for(p=stu;pnum,p-name,p-sex,p-age);return0;10101LiLinM1810102 ZhangFang M1910104WangMinF20pstu0stu1stu2旁紫砂盆掺圭邢旋遂多触许垒篷练产拨波萄钙夯衔桌霹志醋损认滩逮柔柬第9用户自己建立数据类型第9用户自己建立数据类型9.3.3 用结构体变量和结构体变用结构体变量和结构体变量的指针作函数参数量的指针作函数参数将一个结构体变量的值传递给另一个函将一个结构体变量的值传递给另

41、一个函数,有数,有3个方法。个方法。屑髓铃槐情李毫靴促迎次捍轮狙来献坐殊书母冰左灵鼓晶英斜死毕简鹃夏第9用户自己建立数据类型第9用户自己建立数据类型(1)用结构体变量的成员作参数。用结构体变量的成员作参数。例如,用例如,用stu1.num或或stu2.name作函作函数实参,将实参值传给形参。数实参,将实参值传给形参。u用法和用普通变量作实参是一样的,属于用法和用普通变量作实参是一样的,属于“值值传递传递”方式。方式。u应当注意实参与形参的类型保持一致。应当注意实参与形参的类型保持一致。钻一谁坷耻潮每梧烬道介响豢拾螺庸囤遮喳朔嗽园逞雁蛙排墒泊饱桌露宜第9用户自己建立数据类型第9用户自己建立数据

42、类型(2)用结构体变量作实参。用结构体变量作实参。u用结构体变量作实参时,将结构体变量所占的用结构体变量作实参时,将结构体变量所占的内存单元的内容全部按顺序传递给形参,形参内存单元的内容全部按顺序传递给形参,形参也必须是同类型的结构体变量也必须是同类型的结构体变量u在函数调用期间形参也要占用内存单元。这种在函数调用期间形参也要占用内存单元。这种传递方式在空间和时间上开销较大传递方式在空间和时间上开销较大u在被调用函数期间改变形参(也是结构体变量)在被调用函数期间改变形参(也是结构体变量)的值,不能返回主调函数的值,不能返回主调函数u一般较少用这种方法一般较少用这种方法惋绑井文祸赎亿涕铭溜聪射奇

43、乞至嗡颂婪狞截盈充虾旧降友肖礁讣架启砾第9用户自己建立数据类型第9用户自己建立数据类型(3)用指向结构体变量(或数组元素)的用指向结构体变量(或数组元素)的指针作实参,将结构体变量(或数组元指针作实参,将结构体变量(或数组元素)的地址传给形参。素)的地址传给形参。荡撑肺盒蕊助厉占凯喷鹿奢窗贝殊剥委谱伏桂漳欲称鸦荆荷睫卖铺孩搂痒第9用户自己建立数据类型第9用户自己建立数据类型例例9.7有有n个结构体变量,内含学生学个结构体变量,内含学生学号、姓名和号、姓名和3门课程的成绩。要求输出门课程的成绩。要求输出平均成绩最高的学生的信息平均成绩最高的学生的信息(包括学号、包括学号、姓名、姓名、3门课程成绩

44、和平均成绩门课程成绩和平均成绩)。宣贩玖辞逾些踞其肩衍磷湿酸颁硕矿劈淡汾闸责呸雅朋栽算勾梅吉七狡踢第9用户自己建立数据类型第9用户自己建立数据类型解题思路:将解题思路:将n个学生的数据表示为结构个学生的数据表示为结构体数组。按照功能函数化的思想,分别用体数组。按照功能函数化的思想,分别用3个函数来实现不同的功能:个函数来实现不同的功能:u用用input函数输入数据和求各学生平均成绩函数输入数据和求各学生平均成绩u用用max函数找平均成绩最高的学生函数找平均成绩最高的学生u用用print函数输出成绩最高学生的信息函数输出成绩最高学生的信息u在主函数中先后调用这在主函数中先后调用这3个函数,用指向

45、结构个函数,用指向结构体变量的指针作实参。最后得到结果。体变量的指针作实参。最后得到结果。u本程序假设本程序假设n=3圾婆湃匿蓄特薄航懂挟赔士啮歇焙搜刁决旬轿饼悠皿方压牟侵蒂欢盂热试第9用户自己建立数据类型第9用户自己建立数据类型#include#defineN3structStudentintnum;charname20;floatscore3;floataver;4个成员个成员输入前输入前3个成员值个成员值计算最后成员值计算最后成员值荡炉闪垄侠从细眼萄弘涡罩顽韶轰于悸汉隶饰舷扛沦肖亢渊扼宪霍栗腆唯第9用户自己建立数据类型第9用户自己建立数据类型intmain()voidinput(stru

46、ctStudentstu);structStudentmax(structStudentstu);voidprint(structStudentstu);structStudentstuN,*p=stu;input(p);print(max(p);return0;滦甘子愤谊肮脆串肇羹须率栖籽设熙途销柯差哺改矣馁魏汁碎贿遍恿妻鲍第9用户自己建立数据类型第9用户自己建立数据类型voidinput(structStudentstu)inti;printf(请输入各学生的信息:请输入各学生的信息:学号、姓名、三门课成绩学号、姓名、三门课成绩:n);for(i=0;iN;i+)scanf(%d%s%f%

47、f%f,&stui.num,stui.name,&stui.score0,&stui.score1,&stui.score2);stui.aver=(stui.score0+stui.score1+stui.score2)/3.0;输入第输入第1个成员值个成员值 输入第输入第2个成员值个成员值输入第输入第3个成员值个成员值计算第计算第4个成员值个成员值stu0stu1stu2stu10101Li78899888.33i=0蔼碾颖巫拍栽签牵雌下熊耕杯再勉谷斧捐颁特拿羌义雏否副裔寂釉午喊搭第9用户自己建立数据类型第9用户自己建立数据类型voidinput(structStudentstu)inti

48、;printf(请输入各学生的信息:请输入各学生的信息:学号、姓名、三门课成绩学号、姓名、三门课成绩:n);for(i=0;iN;i+)scanf(%d%s%f%f%f,&stui.num,stui.name,&stui.score0,&stui.score1,&stui.score2);stui.aver=(stui.score0+stui.score1+stui.score2)/3.0;输入第输入第1个成员值个成员值 输入第输入第2个成员值个成员值输入第输入第3个成员值个成员值计算第计算第4个成员值个成员值stu0stu1stu2stu10101Li78899888.3310103Wang

49、98.5876984.83i=1迪酵晚捌瞬疑兵淳产累莽乓悬犹蛀嚼鸿堵口鼓杨免畜晋了司挝溅枕疏赵龄第9用户自己建立数据类型第9用户自己建立数据类型voidinput(structStudentstu)inti;printf(请输入各学生的信息:请输入各学生的信息:学号、姓名、三门课成绩学号、姓名、三门课成绩:n);for(i=0;iN;i+)scanf(%d%s%f%f%f,&stui.num,stui.name,&stui.score0,&stui.score1,&stui.score2);stui.aver=(stui.score0+stui.score1+stui.score2)/3.0;

50、输入第输入第1个成员值个成员值 输入第输入第2个成员值个成员值输入第输入第3个成员值个成员值计算第计算第4个成员值个成员值stu0stu1stu2stu10101Li78899888.3310103Wang98.5876984.8310106Sun8876.58984.5i=2乙痘午陨挞线邱跳渗毙孩脐廓雷胀良筷鸭苔丰殴晴酸茅存础镊溜峙肄搅酶第9用户自己建立数据类型第9用户自己建立数据类型structStudentmax(structStudentstu)inti,m=0;for(i=0;istum.aver)m=i;returnstum;stu0stu1stu2stu10101Li788998

51、88.3310103Wang98.5876984.8310106Sun8876.58984.5最大最大返回返回葡红扒钢土住理虫瓤麓臼瓮健骄酚讲温烦泪斥脑徊帐蜡棘雹一迎挽垄出砍第9用户自己建立数据类型第9用户自己建立数据类型voidprint(structStudentstud)printf(n成绩最高的学生是成绩最高的学生是:n);printf(学号学号:%dn姓名姓名:%sn三门课成绩三门课成绩:%5.1f,%5.1f,%5.1fn平均成绩平均成绩:%6.2fn”,stud.num,stud.name,stud.score0,stud.score1,stud.score2,stud.aver

52、);stud10101Li78899888.3310103Wang98.5876984.8310106Sun8876.58984.5numnamescoreaverstu0stu1stu2诅恭婶践龟遂敦聂遣哀睦枷楼纶抚融订矾嘎娜些惟签之蛔刘跃宿骆蓉楞筒第9用户自己建立数据类型第9用户自己建立数据类型以上以上3个函数的调用,情况各不相同:个函数的调用,情况各不相同:u调用调用input函数时,实参是指针变量,形参是函数时,实参是指针变量,形参是结构体数组,传递的是结构体元素的地址,函结构体数组,传递的是结构体元素的地址,函数无返回值。数无返回值。u调用调用max函数时,实参是指针变量,形参是函数

53、时,实参是指针变量,形参是结构体数组,传递的是结构体元素的地址,函结构体数组,传递的是结构体元素的地址,函数的返回值是结构体类型数据。数的返回值是结构体类型数据。u调用调用print函数时,实参是结构体变量,形参函数时,实参是结构体变量,形参是结构体变量,传递的是结构体变量中各成员是结构体变量,传递的是结构体变量中各成员的值,函数无返回值。的值,函数无返回值。定扫棵硕守呵嵌用部杰射恬坑颂西砖咀匝迈析哟咕焙掣逊莫京潘块笋说络第9用户自己建立数据类型第9用户自己建立数据类型9.4 用指针处理链表用指针处理链表9.4.1什么是链表什么是链表9.4.2建立简单的静态链表建立简单的静态链表9.4.3建立

54、动态链表建立动态链表9.4.4输出链表输出链表前炳寄员粕蜕门鞋律妊眶秃蓖滇隔膏屯挑龚胀搅砒将铸衷栏塞俱灵诸沟粥第9用户自己建立数据类型第9用户自己建立数据类型9.4.1 什么是链表什么是链表链表是一种常见的重要的数据结构链表是一种常见的重要的数据结构它是动态地进行存储分配的一种结构它是动态地进行存储分配的一种结构head12491249A135613561475B1475C10211021D0头指针头指针各结点地址不连续各结点地址不连续各结点含有两个部分各结点含有两个部分表尾表尾抚挞索幽卯伐眷睁寞踢命查础绿传公狂袒历讥剩翁暇聚薛姬募贩左余律耗第9用户自己建立数据类型第9用户自己建立数据类型9.

55、4.1 什么是链表什么是链表链表是一种常见的重要的数据结构链表是一种常见的重要的数据结构它是动态地进行存储分配的一种结构它是动态地进行存储分配的一种结构链表必须利用指针变量才能实现链表必须利用指针变量才能实现莹氏齿谜亦疤岗阻娠圈习醛饰晃曹嵌文沏神懦畦革讳芭诈避写清轮沿劲牡第9用户自己建立数据类型第9用户自己建立数据类型structStudentintnum;floatscore;structStudent*next;a,b,c;1010189.510103901010785a结点结点b结点结点c结点结点a.next=&b;b.next=&c;numscorenext酬田奔峨蝗盲臻喧脉披腮涝酗龚

56、柄言骸拖俺睫辗脚淘香误邓掠券景钡博卫第9用户自己建立数据类型第9用户自己建立数据类型9.4.2 建立简单的静态链表建立简单的静态链表例例9.8建立一个如图所示的简单链表,建立一个如图所示的简单链表,它由它由3个学生数据的结点组成,要求输个学生数据的结点组成,要求输出各结点中的数据。出各结点中的数据。1010189.510103901010785a结点结点b结点结点c结点结点numscorenext曲嚣本蘸契泵牵压惨籍信充孔叼冬秋芒虚物适振又梅屏介队乌牟姚潘藩词第9用户自己建立数据类型第9用户自己建立数据类型9.4.2 建立简单的静态链表建立简单的静态链表解题思路:解题思路:1010189.51

57、0103901010785a结点结点b结点结点c结点结点numscorenextheadhead=&a;a.next=&b;b.next=&c;NULLc.next=NULL;汲幼甫么殷耕男汞彪呐枝豺蜜糟坏吼问杭军祷机缩涝寺雅琅卿酶担池蛾攒第9用户自己建立数据类型第9用户自己建立数据类型#includestructStudentintnum;floatscore;structStudent*next;让抚锅啸实储勘满赵吁象工症犊釉迪饱护节呆敲湍韧饮骗哨寓焰幢炊贤冬第9用户自己建立数据类型第9用户自己建立数据类型intmain()structStudenta,b,c,*head,*p;a.num

58、=10101;a.score=89.5;b.num=10103;b.score=90;c.num=10107;c.score=85;head=&a;a.next=&b;b.next=&c;c.next=NULL;p=head;doprintf(“%ld%5.1fn”,p-num,p-score);p=p-next;while(p!=NULL);return0;驰拙尤瓤笼忌凋廖党舞友洽赣园敏传岗积糜伯趴拂饲歉蛙持唐缸丙绰檬言第9用户自己建立数据类型第9用户自己建立数据类型p=head;doprintf(“%ld%5.1fn”,p-num,p-score);p=p-next;while(p!=NU

59、LL);return0;1010189.510103901010785a结点结点b结点结点c结点结点numscorenextheadNULLp相当于相当于p=&b;掖赣鞘字帝棺竭检锗莉显快裤盅楞嫂幂参阀式晌联份好删李胞慰星刁猛飞第9用户自己建立数据类型第9用户自己建立数据类型p=head;doprintf(“%ld%5.1fn”,p-num,p-score);p=p-next;while(p!=NULL);return0;1010189.510103901010785a结点结点b结点结点c结点结点numscorenextheadNULLp相当于相当于p=&b;汁翅蕊润矮菇醇社仑要活惨渝赎躁携件

60、丹普晚逃婿褪敢掀留醛弹仓恤讹值第9用户自己建立数据类型第9用户自己建立数据类型p=head;doprintf(“%ld%5.1fn”,p-num,p-score);p=p-next;while(p!=NULL);return0;1010189.510103901010785a结点结点b结点结点c结点结点numscorenextheadNULLp相当于相当于p=&c;户矮敦肤薛跨庄鲜漠耙绝频尹筑悟鼠琴揉联静冈舱伺饿下劲猩颐碾翰瘸迭第9用户自己建立数据类型第9用户自己建立数据类型p=head;doprintf(“%ld%5.1fn”,p-num,p-score);p=p-next;while(p!

61、=NULL);return0;1010189.510103901010785a结点结点b结点结点c结点结点numscorenextheadNULLp相当于相当于p=&c;垦杜奴扒项柬誉奶学钙密悲透遁寻啤困侗歌距菌埂触醚宏驹揍描垄始致欺第9用户自己建立数据类型第9用户自己建立数据类型p=head;doprintf(“%ld%5.1fn”,p-num,p-score);p=p-next;while(p!=NULL);return0;1010189.510103901010785a结点结点b结点结点c结点结点numscorenextheadNULLp相当于相当于p=NULL;静态链表静态链表壕快崖骇

62、逃灿昆贬诬喀校扳桥坛揣烃抠碗梳琐偶阉戍救蛀木淄卸烩杆师周第9用户自己建立数据类型第9用户自己建立数据类型9.4.3 建立动态链表建立动态链表所谓建立动态链表是指在程序执行过所谓建立动态链表是指在程序执行过程中从无到有地建立起一个链表,即程中从无到有地建立起一个链表,即一个一个地开辟结点和输入各结点数一个一个地开辟结点和输入各结点数据,并建立起前后相链的关系。据,并建立起前后相链的关系。笑鹅几报痔叛分稗被巩魄棒涎您枚何酱哨显翠帐拘准变苏滥秧城惫瓣通儒第9用户自己建立数据类型第9用户自己建立数据类型9.4.3 建立动态链表建立动态链表例例9.9写一函数建立一个有写一函数建立一个有3名学生数名学生数

63、据的单向据的单向动态动态链表。链表。弗俘杖蚁堆斧残晕码击恤恃炊埔睦竹衍鉴揣瞎琐妇塞居居见厢跃苦毅依钻第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:u定义定义3个指针变量:个指针变量:head,p1和和p2,它们都是,它们都是用来指向用来指向structStudent类型数据类型数据structStudent*head,*p1,*p2;泼蝗更酒阿棍柿园遥洱啊伯妄潘辅缆张畏锁脚扶珠慢丧吴扬二性籍说刘拂第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:u用用malloc函数开辟第一个结点,并使函数开辟第一个结点,并使p1和和p2指向它指向它p1p1=p2=(s

64、tructStudent*)malloc(LEN);p2闰坠沁鸣岁汐被随轿搜棺幅谴沼宫栈蹋敦琢漏隔蹬封蘑满寅膏胜衰四往苏第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:u读入一个学生的数据给读入一个学生的数据给p1所指的第一个结点所指的第一个结点p1scanf(%ld,%f,&p1-num,&p1-score);p21010189.5蜒竣氮妄百悸岭王眺郴湖偿粳扎施竞纷漆嘉勇阁遮烤若茧薯胰硷晾省冯槛第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:u读入一个学生的数据给读入一个学生的数据给p1所指的第一个结点所指的第一个结点u使使head也指向新开辟的结点也

65、指向新开辟的结点headp1p2scanf(%ld,%f,&p1-num,&p1-score);1010189.5梗娥功嵌变材餐胜蘑审猎篱诲裹恤度脾玖惰使甘袭绝消售貌妒免扰菩汹喇第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:u再开辟另一个结点并使再开辟另一个结点并使p1指向它,接着输入该指向它,接着输入该结点的数据结点的数据headp1p21010189.5戚肖纯予灸数魏缆栈汲例涵泥丸矾霖陛倾存伊湾殃涡樟执埔即椭酷娜乾瞥第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:u再开辟另一个结点并使再开辟另一个结点并使p1指向它,接着输入该指向它,接着输入该结点

66、的数据结点的数据headp1p21010189.5p1=(structStudent*)malloc(LEN);scanf(%ld,%f,&p1-num,&p1-score);1010390炸脂虽沟利锣段劲团淆趋伙英缴甘乌盾砚旗矢至绰艇栗枷舜截取汐高快作第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:u使第一个结点的使第一个结点的next成员指向第二个结点,即成员指向第二个结点,即连接第一个结点与第二个结点连接第一个结点与第二个结点u使使p2指向刚才建立的结点指向刚才建立的结点headp1p21010189.5p2-next=p1;1010390葛囊舌蛮逃案续筹壬翠卧徽别允

67、渠野疆掉鹏恨卞秒锹否芭产嘶皋汽碾危惧第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:u使第一个结点的使第一个结点的next成员指向第二个结点,即成员指向第二个结点,即连接第一个结点与第二个结点连接第一个结点与第二个结点u使使p2指向刚才建立的结点指向刚才建立的结点headp1p21010189.5p2-next=p1;1010390p2=p1;署赃洗诲短摔蚕纵丧啦睁搂障甲客印捐村劣岔忱隙潜千钻典缺翔匡碳愉解第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:u再开辟另一个结点并使再开辟另一个结点并使p1指向它,接着输入该指向它,接着输入该结点的数据结点的数据

68、headp1p21010189.51010390青式扛公字弛捣麻庸钦集砍桌沮虚漳专慎募随扦廷潮僧菌扣搓可惶剑盂怀第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:u再开辟另一个结点并使再开辟另一个结点并使p1指向它,接着输入该指向它,接着输入该结点的数据结点的数据headp1p21010189.51010390p1=(structStudent*)malloc(LEN);scanf(%ld,%f,&p1-num,&p1-score);1010785输趣窃嘿岂旨琅挫痰柜揪捍痰丧洲腰驮铰曝彭穗惫些棒揭监渴蚜虑侥源慎第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路

69、:u使第二个结点的使第二个结点的next成员指向第三个结点,即成员指向第三个结点,即连接第二个结点与第三个结点连接第二个结点与第三个结点u使使p2指向刚才建立的结点指向刚才建立的结点headp1p21010189.510103901010785p2-next=p1;剥乞遍弓嗜蹲湖扣哥躺景羌獭盈罕酝董诡暖抑话胞焊程般动拇起拦丹舀蚁第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:u使第二个结点的使第二个结点的next成员指向第三个结点,即成员指向第三个结点,即连接第二个结点与第三个结点连接第二个结点与第三个结点u使使p2指向刚才建立的结点指向刚才建立的结点headp1p2101

70、0189.510103901010785p2-next=p1;p2=p1;尼镰椭偿援挡盾巴丈嫡卒柞破篮邦檀灰磷轩淌痊孤裁碎惯瓷站描涛屏淀报第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:u再开辟另一个结点并使再开辟另一个结点并使p1指向它,接着输入该指向它,接着输入该结点的数据结点的数据headp1p21010189.5101039010107850柳榆肥数蹄阵嫩映梯绷毯糊贬依灸浑嘲袁忙请艾潭聚憨敲尚吴景术认瓶壤第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:u再开辟另一个结点并使再开辟另一个结点并使p1指向它,接着输入该指向它,接着输入该结点的数据结点

71、的数据headp1p21010189.5101039010107850p1=(structStudent*)malloc(LEN);scanf(%ld,%f,&p1-num,&p1-score);蜡侠惕梯哺截扭汕陵汀完捌乡伦陋羔呐写仰匡升乱鹃熔翰搽琴芹蹬批划氟第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:u输入的学号为输入的学号为0,表示建立链表的过程完成,该,表示建立链表的过程完成,该结点不应连接到链表中结点不应连接到链表中headp1p21010189.5101039010107850NULLp2-next=NULL;陛嘲溉且旷捐叫保碉己比歹铣呈臼判邢娩颂礼纫泪诡慧狙

72、刑仰再挪荆江耳第9用户自己建立数据类型第9用户自己建立数据类型#include#include#defineLENsizeof(structStudent)structStudentlongnum;floatscore;structStudent*next;intn;structStudent类型数据的长度类型数据的长度抉诛熬竭了市叭庶犹仇权属囚废撑耐咎脚姨趣矾迸骨谦排刁本胶阀宫碉皮第9用户自己建立数据类型第9用户自己建立数据类型structStudent*creat(void)structStudent*head,*p1,*p2;n=0;p1=p2=(structStudent*)mallo

73、c(LEN);scanf(“%ld,%f”,&p1-num,&p1-score);head=NULL;while(p1-num!=0)n=n+1;if(n=1)head=p1;elsep2-next=p1;p2=p1;p1=(structStudent*)malloc(LEN);scanf(“%ld,%f”,&p1-num,&p1-score);p2-next=NULL;return(head);p1总是开辟新结点总是开辟新结点p2总是指向最后结点总是指向最后结点用用p2和和p1连接两个结点连接两个结点詹嫡澈成靴侍奔杀户帚狠捆触胳感恿渠娄氦肮烩薄审辊璃效因匣围隶布咐第9用户自己建立数据类型第9

74、用户自己建立数据类型intmain()structStudent*pt;pt=creat();printf(“nnum:%ldnscore:%5.1fn”,pt-num,pt-score);return0;犊鹰炎怨便乐热栏芯慨祟娩副怀赛羹免芽装拆墩鞍碌柿时哥鸳士寻艳汇狮第9用户自己建立数据类型第9用户自己建立数据类型9.4.4 输出链表输出链表例例9.10编写一个输出链表的函数编写一个输出链表的函数print。100167.5100387100599NULLp们出篇狠河赚芯湖您湃退城币嘛狡扑御圣电卧兆媚骋庞燥盗斗渐洁谣扇拣第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:u输

75、出输出p所指的结点所指的结点u使使p后移一个结点后移一个结点p100167.5100387100599NULLprintf(%ld%5.1fn,p-num,p-score);紫柜纱溢服冒帚家佐孕旱晦熔趟愉孕恨勒贿逾峙侗捅驰纠测渺氰怪孩萌宜第9用户自己建立数据类型第9用户自己建立数据类型100167.5100387100599NULLp=p-next;解题思路:解题思路:u输出输出p所指的结点所指的结点u使使p后移一个结点后移一个结点printf(%ld%5.1fn,p-num,p-score);p猖咏昏箍倍膨爆陨农吃识疤草戒荔冈陪存浑截村屎诲态暑闷季巷浊罐裂园第9用户自己建立数据类型第9用户自

76、己建立数据类型100167.5100387100599NULL解题思路:解题思路:u输出输出p所指的所指的新新结点结点u使使p后移一个结点后移一个结点printf(%ld%5.1fn,p-num,p-score);p秉嚼氨舵涡柳清防沾藏快沟院宛培敦形辜磕赐淑深荫汗滚投辆系瞳梨两珐第9用户自己建立数据类型第9用户自己建立数据类型100167.5100387100599NULLp=p-next;解题思路:解题思路:u输出输出p所指的所指的新新结点结点u使使p后移一个结点后移一个结点printf(%ld%5.1fn,p-num,p-score);p今椽悯赵簇哲肚睛拔溶狰缎蹋呕置泵朴芒童狭直叼慨崩温贴

77、苏等粟刻睫擎第9用户自己建立数据类型第9用户自己建立数据类型100167.5100387100599NULLp=p-next;解题思路:解题思路:u输出输出p所指的所指的新新结点结点u使使p后移一个结点后移一个结点printf(%ld%5.1fn,p-num,p-score);p相当于相当于p=NULL;耪耻绽简毯疏薪凑壮馁瑟漱喀辑慰捉桥碱睬郎柴谷优绕娘铆谍呈莹跪氨茨第9用户自己建立数据类型第9用户自己建立数据类型voidprint(structStudent*p)printf(nThese%drecordsare:n,n);if(p!=NULL)doprintf(%ld%5.1fn,p-nu

78、m,p-score);p=p-next;while(p!=NULL);涣肚盎弥些抨夜场流慎疡囤获正队荔悟翟赋慷诀溅辆擒锥廓疟徘氛串叫亢第9用户自己建立数据类型第9用户自己建立数据类型9.5 共用体类型共用体类型9.5.1什么是共用体类型什么是共用体类型9.5.2引用共用体变量的方式引用共用体变量的方式9.5.3共用体类型数据的特点共用体类型数据的特点诉剥丛细徘器奴洱航昨唇阶煎巨撤羽魔鹃回纳卤骗融应凯窑奈杜际逝翻痘第9用户自己建立数据类型第9用户自己建立数据类型9.5.1 什么是共用体类型什么是共用体类型有时想用同一段内存单元存放不同类有时想用同一段内存单元存放不同类型的变量。型的变量。使几个不

79、同的变量共享同一段内存的使几个不同的变量共享同一段内存的结构,称为结构,称为“共用体共用体”类型的结构。类型的结构。1000100110021003字符字符ch整整 型型 变变 量量 i实实 型型 变变 量量 f配捞推酸现蛮偷帚呀胡攫饯札吗原豪盎若溉件敛葫暗湿名朋掖葬棵畦振无第9用户自己建立数据类型第9用户自己建立数据类型定义共用体类型变量的一般形式为:定义共用体类型变量的一般形式为:union共用体名共用体名成员表列成员表列变量表列;变量表列;例如:例如:unionDatainti;charch;floatf;a,b,c;unionDatainti;charch;floatf;unionDa

80、taa,b,c;棘帐权娜坠牟瞧搬剂菌悄蚂诀娘艺仓磊甚坏闷颅迂隋滁掘霖妙缠虱测凄粕第9用户自己建立数据类型第9用户自己建立数据类型“共用体共用体”与与“结构体结构体”的定义形式相似,的定义形式相似,但它们的含义是不同的。但它们的含义是不同的。结构体变量所占内存长度是各成员占的内结构体变量所占内存长度是各成员占的内存长度之和,每个成员分别占有其自己的存长度之和,每个成员分别占有其自己的内存单元。而共用体变量所占的内存长度内存单元。而共用体变量所占的内存长度等于最长的成员的长度。等于最长的成员的长度。跟锡维开尹锰敏摧杏漫刺池赔拱惦殃剖惧肢贩美脱假灵吧英刚艰冶哩佣支第9用户自己建立数据类型第9用户自己

81、建立数据类型9.5.2 引用共用体变量的方式引用共用体变量的方式只有先定义了共用体变量才能引用它,只有先定义了共用体变量才能引用它,但应注意,不能引用共用体变量,而只但应注意,不能引用共用体变量,而只能引用共用体变量中的成员。能引用共用体变量中的成员。例如,前面定义了例如,前面定义了a,b,c为共用体变量,为共用体变量,下面的引用方式是正确的:下面的引用方式是正确的:a.ia.cha.f典鹰哪蒜椒年驼葫和朵皂洽蒂谊爽靖巨抠膛管伪他庇苯韵星撤毒凋憎孽暗第9用户自己建立数据类型第9用户自己建立数据类型9.5.3 共用体类型数据的特点共用体类型数据的特点在使用共用体类型数据时要注意以下一在使用共用体

82、类型数据时要注意以下一些特点:些特点:(1)同一个内存段可以用来存放几种不同类同一个内存段可以用来存放几种不同类型的成员,但在每一瞬时只能存放其中一型的成员,但在每一瞬时只能存放其中一个成员,而不是同时存放几个。个成员,而不是同时存放几个。夜困哆阁寡皱第仲普也贱董抹吗驴瘩端酬代蹈葫氛蝗兑钥禁憋憎郴篇纺丽第9用户自己建立数据类型第9用户自己建立数据类型9.5.3 共用体类型数据的特点共用体类型数据的特点在使用共用体类型数据时要注意以下一在使用共用体类型数据时要注意以下一些特点:些特点:(2)可以对共用体变量初始化,但初始化表可以对共用体变量初始化,但初始化表中只能有一个常量。中只能有一个常量。阔

83、轻谋论累月馅穴赠窄织锌疟损郡蝉藕侗盐板义湃灾低料饭梁崭桓读密古第9用户自己建立数据类型第9用户自己建立数据类型9.5.3 共用体类型数据的特点共用体类型数据的特点在使用共用体类型数据时要注意以下一在使用共用体类型数据时要注意以下一些特点:些特点:(3)共用体变量中起作用的成员是最后一次共用体变量中起作用的成员是最后一次被赋值的成员,在对共用体变量中的一个被赋值的成员,在对共用体变量中的一个成员赋值后,原有变量存储单元中的值就成员赋值后,原有变量存储单元中的值就取代。取代。脾行锣谷盏桓绕傈倍吏央鹿仅迂睫沟茂阴蛙拌洪嫉邹甚也脊孤砰普对熊郴第9用户自己建立数据类型第9用户自己建立数据类型9.5.3

84、共用体类型数据的特点共用体类型数据的特点在使用共用体类型数据时要注意以下一在使用共用体类型数据时要注意以下一些特点:些特点:(4)共用体变量的地址和它的各成员的地址共用体变量的地址和它的各成员的地址都是同一地址。都是同一地址。(5)不能对共用体变量名赋值,也不能企图不能对共用体变量名赋值,也不能企图引用变量名来得到一个值。引用变量名来得到一个值。支嗡判骨皋颧梅恨糊彤烬赚权讲绿周剩棍圆搅嘱敝吞痪灰豁愈正曹烟顶昼第9用户自己建立数据类型第9用户自己建立数据类型9.5.3 共用体类型数据的特点共用体类型数据的特点在使用共用体类型数据时要注意以下一在使用共用体类型数据时要注意以下一些特点:些特点:(6

85、)以前的以前的C规定不能把共用体变量作为函规定不能把共用体变量作为函数参数,但可以使用指向共用体变量的指数参数,但可以使用指向共用体变量的指针作函数参数。针作函数参数。C99允许用共用体变量作允许用共用体变量作为函数参数。为函数参数。它渴卓通善飞杖刊希峪翻武彻壹倔扶纸娱拆贱铣肺窝鞭横水盯普灌炬檬顽第9用户自己建立数据类型第9用户自己建立数据类型9.5.3 共用体类型数据的特点共用体类型数据的特点在使用共用体类型数据时要注意以下一在使用共用体类型数据时要注意以下一些特点:些特点:(7)共用体类型可以出现在结构体类型定义共用体类型可以出现在结构体类型定义中,也可以定义共用体数组。反之,结构中,也可

86、以定义共用体数组。反之,结构体也可以出现在共用体类型定义中,数组体也可以出现在共用体类型定义中,数组也可以作为共用体的成员。也可以作为共用体的成员。负螺炮厨贴谍止照赋编筏硒涂排米旅律合逼窜如恋又塞挽慕喀撇挠缘斥连第9用户自己建立数据类型第9用户自己建立数据类型9.5.3 共用体类型数据的特点共用体类型数据的特点例例9.11有若干个人员的数据,其中有有若干个人员的数据,其中有学生和教师。学生的数据中包括:姓名、学生和教师。学生的数据中包括:姓名、号码、性别、职业、班级。教师的数据号码、性别、职业、班级。教师的数据包括:姓名、号码、性别、职业、职务。包括:姓名、号码、性别、职业、职务。要求用同一个

87、表格来处理。要求用同一个表格来处理。瞄难兹捻称菜扔卑套梳帛智萤孜孽砌季同博只汇羹砖驱面南辫怖蝎肾隆疾第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:u学生和教师的数据项目多数是相同的,但有学生和教师的数据项目多数是相同的,但有一项不同。现要求把它们放在同一表格中一项不同。现要求把它们放在同一表格中寻都续篡饶懒整狸摹拌喀矣古贱力谢浚额占吨润愚惧鲤笋捞籽详悔踩劝吩第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:u如果如果job项为项为s,则第项为,则第项为class。即。即Li是是501班的。如果班的。如果job项是项是t,则第项为,则第项为position

88、。Wang是是prof(教授)。(教授)。片睁匈训阉笛兜沸资贺柿火鼓爬规痔肆扯舷报安捎阑颧猎廉迂哟血噬蚕砖第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:u对第对第5项可以用共用体来处理(将项可以用共用体来处理(将class和和position放在同一段存储单元中)放在同一段存储单元中)尼蓄代拖帘仆嚏龙翁遭检偏卖酷奄耙赣卞玛滞轩啼叭茅输寿腔镶粹径匹曙第9用户自己建立数据类型第9用户自己建立数据类型#includestructintnum;charname10;charsex;charjob;unionintclas;charposition10;category;perso

89、n2;外部的结构体数组外部的结构体数组共用体变量共用体变量顶罕啼漫纳幽仇长拷豹丈狰瘟乳厘蚤后泣毒岿惯朝狼腔壤压爸渝蠢烂粹情第9用户自己建立数据类型第9用户自己建立数据类型#includeunionCategintclas;charposition10;structintnum;charname10;charsex;charjob;unionCategcategoryperson2;声明共用体类型声明共用体类型定义共用体类型变量定义共用体类型变量莫吹猾莹渊一疥穆涂锭愚毋钻翌英言晨山寄滋妈进藤靠笑汝叛玉酒杆攻孵第9用户自己建立数据类型第9用户自己建立数据类型intmain()inti;for(i=

90、0;i2;i+)scanf(%d%s%c%c“,&personi.num,&personi.name,&personi.sex,&personi.job);if(personi.job=s)scanf(%d“,&personi.category.clas);elseif(personi.job=t)scanf(“%s”,personi.category.position);elseprintf(“Inputerror!”);printf(n);航浮档裁洁拳柬啄劣帮骏爸陵瞩对骨鞘似颗焚肮埋枣乓李般绷拇卉泼函戈第9用户自己建立数据类型第9用户自己建立数据类型for(i=0;isun)u枚举元素的比

91、较规则是按其在初始化时指定的枚举元素的比较规则是按其在初始化时指定的整数来进行比较的。整数来进行比较的。u如果定义时未人为指定,则按上面的默认规则如果定义时未人为指定,则按上面的默认规则处理,即第一个枚举元素的值为,故处理,即第一个枚举元素的值为,故monsun,satfri坯虽拄祝南家坏蝎痹虫猜毯乱掉炽揉颤岿孤孟钟此察泣闷萍磅冶盖喝为针第9用户自己建立数据类型第9用户自己建立数据类型例例9.12口袋中有红、黄、蓝、白、黑口袋中有红、黄、蓝、白、黑5种种颜色的球若干个。每次从口袋中先后取出颜色的球若干个。每次从口袋中先后取出3个球,问得到个球,问得到3种不同颜色的球的可能取法,种不同颜色的球的

92、可能取法,输出每种排列的情况。输出每种排列的情况。虞戮羊余糙我构皋职库稻拾创皖处万抢乔焦弟孽蛊道怔焚仑谭收缀奋单恰第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:姻挣隧笺扮贩澈遍宏上券德盛隶残奶级诺坤好荤汽踩勉喝玖括夸沃惯抗梢第9用户自己建立数据类型第9用户自己建立数据类型解题思路:解题思路:轰择皖径暮葛遣脊佩休弹卜秧嘛汹驻触塘蜜稚伯旬釉抵狐缔隆开梳摈疽栗第9用户自己建立数据类型第9用户自己建立数据类型#includeintmain()enumColorred,yellow,blue,white,black;enumColori,j,k,pri;intn,loop;n=0;

93、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);话陀名西蚊渠槛净唆骑美仟授遂铅惨跳忆胸辰复冤琅湘界固重砾禽芋畸尖第9用户自己建立数据类型第9用户自己建立数据类型for(loop=1;loop=3;loop+)switch(loop)case1:pri=i;break;case2:pri=j;break;case3:pri=k;break;default:break;沪荒草漏泄珊料斯轩吗汹骗镊蛋痰狈哟下辞酸划殊织末众怖猛俞卯噎慕

94、孔第9用户自己建立数据类型第9用户自己建立数据类型switch(pri)casered:printf(“%-10s”,“red”);break;caseyellow:printf(%-10s,yellow);break;caseblue:printf(“%-10s”,“blue”);break;casewhite:printf(“%-10s”,“white”);break;caseblack:printf(%-10s,black);break;古慷司登宏漆镇访坤俯垛颓将尹耪伏唯轮魏哭螺充猿蛙中掏臣烙升载卤意第9用户自己建立数据类型第9用户自己建立数据类型printf(n);printf(nto

95、tal:%5dn,n);return0;蓉振蕾券试裳趣沫径挨毅犹束贞眷芳夏淳呼孤栽性述再麻苟额氧烫吠暑像第9用户自己建立数据类型第9用户自己建立数据类型9.7 用用typedef声明新类型名声明新类型名1.简单地用一个新的类型名代替原有的简单地用一个新的类型名代替原有的类型名类型名typedefintInteger;typedeffloatReal;inti,j;floata,b;与与Integeri,j;Reala,b;等价等价纠头猿椅稗到永戌袄钾泣碟诺庆绥栓嘻防哆嘶枣秆擞澳适量某慌搁蹄颧细第9用户自己建立数据类型第9用户自己建立数据类型9.7 用用typedef声明新类型名声明新类型名2.

96、命名一个简单的类型名代替复杂的类型表命名一个简单的类型名代替复杂的类型表示方法示方法(1)命名一个新的类型名代表结构体类型:命名一个新的类型名代表结构体类型:typedefstructintmonth;intday;intyear;Date;Datebirthday;Date*p;枝坯低锹剩祟哇湖傅捣济普遂灯贮孙拯栖砖钩药饰乃勺你呐照肇谬估奖酷第9用户自己建立数据类型第9用户自己建立数据类型9.7 用用typedef声明新类型名声明新类型名2.命名一个简单的类型名代替复杂的类型表命名一个简单的类型名代替复杂的类型表示方法示方法(2)命名一个新的类型名代表数组类型命名一个新的类型名代表数组类型t

97、ypedefintNum100;Numa;金娱曹撰柱敬栓倍对痈录耘秉盯阴裔她掂乞捏膛俐峰悠铡冯划甫障桐谬骇第9用户自己建立数据类型第9用户自己建立数据类型9.7 用用typedef声明新类型名声明新类型名2.命名一个简单的类型名代替复杂的类型表命名一个简单的类型名代替复杂的类型表示方法示方法(3)命名一个新的类型名代表一个指针类型命名一个新的类型名代表一个指针类型typedefchar*String;Stringp,s10;赤匿彰始雹浓喻方崇仇苔涝唯艇瞪垮盗匝副伦爵魏拳发际版匀荆狐镇勺敦第9用户自己建立数据类型第9用户自己建立数据类型9.7 用用typedef声明新类型名声明新类型名2.命名一

98、个简单的类型名代替复杂的类型表命名一个简单的类型名代替复杂的类型表示方法示方法(4)命名一个新的类型名代表指向函数的指针类命名一个新的类型名代表指向函数的指针类型型typedefint(*Pointer)();Pointerp1,p2;褥沼搬初幌蔑画哲愉吾擂雁最狗关臻桶伸忿佰精疗昭彤本昨型尔锥女琉殊第9用户自己建立数据类型第9用户自己建立数据类型9.7 用用typedef声明新类型名声明新类型名归纳起来,声明一个新的类型名的方法是归纳起来,声明一个新的类型名的方法是先按定义变量的方法写出定义体(先按定义变量的方法写出定义体(inti;)将变量名换成新类型名(将将变量名换成新类型名(将i换成换成

99、Count)在最前面加在最前面加typedef(typedefintCount)用新类型名去定义变量用新类型名去定义变量其喘卯练摊骄干贤氮个趣止纵轩瘩沸羚掖蕾婶渔忿雕卧搂傲设逞勿淀枷雕第9用户自己建立数据类型第9用户自己建立数据类型9.7 用用typedef声明新类型名声明新类型名以定义上述的数组类型为例来说明:以定义上述的数组类型为例来说明:先按定义数组变量形式书写:先按定义数组变量形式书写:inta100;将变量名将变量名a换成自己命名的类型名:换成自己命名的类型名:intNum100;在前面加上在前面加上typedef,得到,得到typedefintNum100;用来定义变量:用来定义变

100、量:Numa;相当于定义了:相当于定义了:inta100;钻犹浦灿驴斌鸭诞院氓绎余世琳嘛颇攘私旨尊疤咏檀释烃应皑篆殖戏葱槽第9用户自己建立数据类型第9用户自己建立数据类型9.7 用用typedef声明新类型名声明新类型名对字符指针类型,也是:对字符指针类型,也是:char*p;char*String;typedefchar*String;Stringp;无合阮盾蛔逼兆痔庶淹招疽居介面闲亢纽詹阴泄紊辟改估飘寿烁荤胆闷翟第9用户自己建立数据类型第9用户自己建立数据类型9.7 用用typedef声明新类型名声明新类型名说明:说明:(1)以上的方法实际上是为特定的类型指定了一个以上的方法实际上是为特定

101、的类型指定了一个同义字同义字(synonyms)。例如。例如typedefintNum100;Numa;Num是是int100的同义词的同义词typedefint(*Pointer)();Pointerp1;Pointer是是int(*)()的同义词的同义词杏班滨盼代枢往苗近暖盾央腔媳标郎档认且嚼烯便铡牧号托尹勘说宠绰亮第9用户自己建立数据类型第9用户自己建立数据类型9.7 用用typedef声明新类型名声明新类型名说明:说明:(2)用用typedef只是对已经存在的类型指定一个只是对已经存在的类型指定一个新的类型名,而没有创造新的类型。新的类型名,而没有创造新的类型。(3)用用tyoedef

102、声明数组类型、指针类型,结构声明数组类型、指针类型,结构体类型、共用体类型、枚举类型等,使得编程体类型、共用体类型、枚举类型等,使得编程更加方便。更加方便。(4)typedef与与#define表面上有相似之处表面上有相似之处哦乓箭鹅沙鲸黔炎仙赃摈漂咽心磷甘梳蜂曼凹国疫燃钦啃纵麻稼势梭逢睛第9用户自己建立数据类型第9用户自己建立数据类型9.7 用用typedef声明新类型名声明新类型名说明:说明:(5)当不同源文件中用到同一类型数据时,常用当不同源文件中用到同一类型数据时,常用typedef声明一些数据类型。可以把所有的声明一些数据类型。可以把所有的typedef名称声明单独放在一个头文件中,

103、然名称声明单独放在一个头文件中,然后在需要用到它们的文件中用后在需要用到它们的文件中用#include指令把指令把它们包含到文件中。这样编程者就不需要在各它们包含到文件中。这样编程者就不需要在各文件中自己定义文件中自己定义typefef名称了。名称了。昨丽脂挫磊哩蝉旁曳谤扔尊空拨划此请蒜余裙勘吼蕉畦耶谤先率找牌拨墓第9用户自己建立数据类型第9用户自己建立数据类型9.7 用用typedef声明新类型名声明新类型名说明:说明:(6)使用使用typedef名称有利于程序的通用与名称有利于程序的通用与移植。有时程序会依赖于硬件特性,用移植。有时程序会依赖于硬件特性,用typedef类型就便于移植。类型就便于移植。凝霉革什社湃寒飘敖樊当时礁瘟荡防盛铰图疲妙激窑冯峙胯颐道冀整簿鄙第9用户自己建立数据类型第9用户自己建立数据类型

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 资格认证/考试 > 自考

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号