第九章 结构体与链表_第1页
第九章 结构体与链表_第2页
第九章 结构体与链表_第3页
第九章 结构体与链表_第4页
第九章 结构体与链表_第5页
已阅读5页,还剩23页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、第九章第九章 结构体与链表结构体与链表结构体概述结构体概述 结构体结构体 结构体是结构体是一种构造数据类型一种构造数据类型 用途:把不同类型的数据组合成一个整体用途:把不同类型的数据组合成一个整体-自定义数据自定义数据类型类型 结构体类型定义结构体类型定义struct 结构体名结构体名 类型标识符类型标识符 成员名成员名1; 类型标识符类型标识符 成员名成员名2; .;成员类型可以是成员类型可以是基本型或构造型基本型或构造型struct是是关键字关键字,不能省略不能省略合法标识符合法标识符可省可省:无名结构体无名结构体 定义结构体类型,描述下列数据定义结构体类型,描述下列数据 (1) (1)

2、学生情况学生情况: : 包含学生的学号、包含学生的学号、 姓名、姓名、 性别、性别、 年年龄、龄、C C语言课程成绩语言课程成绩: :struct studentint no; /*学号学号*/ char name10; /*姓名姓名*/ char sex; /*性别性别*/ int age; /*年龄年龄*/ float score; /*C成绩成绩*/; /*注:注:;不能省不能省*/结构体类型定义描述结构结构体类型定义描述结构的组织形式的组织形式, ,不分配内存不分配内存如考虑如考虑1010门课程成绩,门课程成绩, 加上总成绩与平均成绩,加上总成绩与平均成绩,可作如下定义可作如下定义:

3、: struct studentint no; /*学号学号*/ char name10; /*姓名姓名*/ char sex; /*性别性别*/ int age; /*年龄年龄*/ float score10; /*10门课程成绩门课程成绩*/ float tcj, acj; /*总成绩,总成绩, 平均成绩平均成绩*/; 定义结构体类型,描述下列数据定义结构体类型,描述下列数据 (2)(2)个人数据个人数据: : 包含姓名、性别、年龄、身高、体重、包含姓名、性别、年龄、身高、体重、住址住址: :struct personchar name20; /*姓名姓名*/ char sex; /*性别

4、性别*/ int age; /*年龄年龄*/ float height; /*身高身高*/ float weight; /*体重体重*/ char addr50; /*住址住址*/; (3)(3)日期结构体类型包括日期结构体类型包括年、月、日年、月、日: :struct dateint year; /*年年*/month; /*月月*/day; /*日日*/;(4)(4)如职工信息结构体类型如职工信息结构体类型: :struct personchar name20; /*姓名姓名*/char address40; /*地址地址*/float salary; /*工资工资*/float cost

5、; /*扣款扣款*/struct date hiredate; /*聘任日期聘任日期*/; 结构体类型可以嵌套定义即一个结结构体类型可以嵌套定义即一个结构体类型中的某些成员又是其他结构体类型中的某些成员又是其他结构体类型构体类型结构体类型变量的定义结构体类型变量的定义 先定义结构体类型,再定义结构体变量先定义结构体类型,再定义结构体变量一般形式:一般形式:例例 struct student int num; char name20; char sex; int age; float score; char addr30; ; struct student stu1,stu2; struct 结

6、构体名结构体名 类型标识符类型标识符 成员名;成员名; 类型标识符类型标识符 成员名;成员名; .;struct 结构体名结构体名 变量名表列变量名表列;例例 #define STUDENT struct student STUDENT int num; char name20; char sex; int age; float score; char addr30; ; STUDENT stu1,stu2; 定义结构体类型的同时定义结构体变量定义结构体类型的同时定义结构体变量一般形式:一般形式:struct 结构体名结构体名 类型标识符类型标识符 成员名;成员名; 类型标识符类型标识符 成员

7、名;成员名; .变量名表列变量名表列;例例 struct student int num; char name20; char sex; int age; float score; char addr30; stu1,stu2; 直接定义结构体变量直接定义结构体变量一般形式:一般形式:struct 类型标识符类型标识符 成员名;成员名; 类型标识符类型标识符 成员名;成员名; .变量名表列变量名表列;例例 struct int num; char name20; char sex; int age; float score; char addr30; stu1,stu2; 用用无名结构体无名结

8、构体直接定义直接定义变量变量只能一次只能一次结构体类型声明的说明结构体类型声明的说明 说明说明结构体类型与结构体变量概念不同结构体类型与结构体变量概念不同 类型类型:不分配内存不分配内存; 变量变量:分配内存分配内存 类型类型:不能赋值、存取、运算不能赋值、存取、运算; 变量变量:可以可以结构体可嵌套结构体可嵌套结构体成员名与程序中变量名可相同,不会混淆结构体成员名与程序中变量名可相同,不会混淆结构体类型及变量的作用域与生存期结构体类型及变量的作用域与生存期例例 struct date int month; int day; int year; ; struct student int num

9、; char name20; struct date birthday; stu;numnamebirthdaymonthdayyear例例 struct student int num; char name20; struct date int month; int day; int year; birthday; stu;numnamebirthdaymonthdayyear结构体变量的使用结构体变量的使用 由结构体变量名引用其成员由结构体变量名引用其成员结构体变量结构体变量不能整体引用不能整体引用,只能引用变量只能引用变量成员成员可以将可以将一个结构体变量赋值给另一个结构体变量一个结构体

10、变量赋值给另一个结构体变量结构体嵌套时结构体嵌套时逐级引用逐级引用引用方式:引用方式: 结构体变量名结构体变量名.成员名成员名成员成员( (分量分量) )运算符运算符优先级优先级: : 1 1结合性结合性: :从左向右从左向右例例 struct student int num; char name20; char sex; int age; float score; char addr30; stu1,stu2; stu1.num=10;stu1.score=85.5;stu1.score+=stu2.score; stu1.age+;例例 struct student int num; ch

11、ar name20; char sex; int age; float score; char addr30; stu1,stu2; printf(“%d,%s,%c,%d,%f,%sn”,stu1); ( )stu1=101,“Wan Lin”,M,19,87.5,“DaLian”; ( )例例 struct student int num; char name20; char sex; int age; float score; char addr30; stu1,stu2; stu2=stu1; ( )例例 struct student int num; char name20; str

12、uct date int month; int day; int year; birthday; stu1,stu2;numnamebirthdaymonthdayyearstu1.birthday.month=12;例例 struct student int num; char name20; char sex; int age; float score; char addr30; stu1,stu2; if(stu1=stu2). ( )结构体变量的初始化结构体变量的初始化 形式一形式一:struct 结构体名结构体名 类型标识符类型标识符 成员名;成员名; 类型标识符类型标识符 成员名;

13、成员名; .;struct 结构体名结构体名 结构体变量结构体变量=初始数据初始数据;例例 struct student int num; char name20; char sex; int age; char addr30; ; struct student stu1=112,“Wang Lin”,M,19, “200 Beijing Road”; 形式二形式二:struct 结构体名结构体名 类型标识符类型标识符 成员名;成员名; 类型标识符类型标识符 成员名;成员名; .结构体变量结构体变量=初始数据初始数据;例例 struct student int num; char name20

14、; char sex; int age; char addr30; stu1=112,“Wang Lin”,M,19, “200 Beijing Road”; 形式三形式三:struct 类型标识符类型标识符 成员名;成员名; 类型标识符类型标识符 成员名;成员名; .结构体变量结构体变量=初始数据初始数据;例例 struct int num; char name20; char sex; int age; char addr30; stu1=112,“Wang Lin”,M,19, “200 Beijing Road”; 结构体变量存储分配示意图结构体变量存储分配示意图stru1100010

15、20100110231026name20sexagescore例例 9.1 求某同学上学期求某同学上学期8门课程的总成绩与平均成绩。门课程的总成绩与平均成绩。 程序如下:程序如下:main( ) int i; struct st char xm8; float cj9; float tcj, acj; stu; scanf(%s, stu.xm);); /*输入输入*/for(i=1; i=8;i+) scan(%f, &stu.cji);); stu.tcj=0.0; /*求总成绩求总成绩*/for(i=1; i=8;i+) stu.tcj+=stu.cji; stu.acj=stu

16、.tcji/8; /*求平均成绩求平均成绩*/printf(%s总成绩总成绩=%6.2f, 平均成绩平均成绩=%6.2f,stu.tcj,stu.acj);); 输入数据:输入数据: CHEN 80 86 79 98 88 72 96 66运行结果:运行结果: CHEN的总成绩的总成绩=577.00, 平均成绩平均成绩= 72.13结构体类型数组结构体类型数组 结构体数组的定义结构体数组的定义三种形式:形式一: struct student int num; char name20; char sex; int age; ;struct student stu2;形式二: struct stu

17、dent int num; char name20; char sex; int age; stu2;形式三: struct int num; char name20; char sex; int age; stu2;numnamesexagenumnamesexagestu0stu125B结构体数组初始化与引用结构体数组初始化与引用 结构体数组初始化结构体数组初始化例例 struct int num; char name20; char sex; int age; stu =,;顺序初始化顺序初始化: struct student int num; char name20; char sex

18、; int age; ;struct student stu =100,“Wang Lin”,M,20, 101,“Li Gang”,M,19, 110,“Liu Yan”,F,19; 例例 struct student int num; char name20; char sex; int age; stu =,;分行初始化分行初始化: struct student int num; char name20; char sex; int age; ;struct student stu =100,“Wang Lin”,M,20, 101,“Li Gang”,M,19, 110,“Liu Ya

19、n”,F,19; 全部初始化时维数可省全部初始化时维数可省 结构体数组引用结构体数组引用引用方式:引用方式: 结构体数组名结构体数组名下标下标.成员名成员名 struct student int num; char name20; char sex; int age; str3;stu1.age+;strcpy(,”ZhaoDa”);例例 统计候选人选票统计候选人选票struct person char name20; int count;leader3=“Li”,0,“Zhang”,0,”Wang“,0; main() int i,j; char leader_name20

20、; for(i=1;i=10;i+) scanf(%s,leader_name); for(j=0;j3;j+)if(strcmp(leader_name,)=0) leaderj.count+; for(i=0;i成员名成员名结构体变量名结构体变量名.成员名成员名指向运算符优先级: 1结合方向:从左向右例例 指向结构体的指针变量指向结构体的指针变量main() struct student long int num; char name20; char sex; float score; stu_1,*p; p=&stu_1; stu_1.num=89101;

21、 strcpy(stu_1.name,Li Lin); p-sex=M; p-score=89.5; printf(nNo:%ldnname:%snsex:%cnscore:%fn, (*p).num,p-name,stu_1.sex,p-score);例例 int n; int *p=&n; *p=10; n=10struct student stu1;struct student *p=&stu1;stu1.num=101; (*p).num=101总结:结构体成员变量引用方式总结:结构体成员变量引用方式结构体变量结构体变量.成员名成员名(*p).成员名成员名p-成员名成员

22、名其中,其中,-称为指向运算符称为指向运算符 请分析下列几种运算:请分析下列几种运算:p-np-n+p-n指向结构体数组元素的指针指向结构体数组元素的指针例例 指向结构体数组的指针指向结构体数组的指针struct student int num; char name20; char sex; int age;stu3=10101,Li Lin,M,18, 10102,Zhang Fun,M,19, 10104,Wang Min,F,20;main() struct student *p; for(p=stu;pnum,p-name,p-sex,p-age);numnamesexagestu0p

23、stu1stu2p+1结构体变量作为函数参数结构体变量作为函数参数 用结构体变量的成员作参数用结构体变量的成员作参数-值传递值传递用指向结构体变量或数组的指针作参数用指向结构体变量或数组的指针作参数-地地址传递址传递用结构体变量作参数用结构体变量作参数-多值传递多值传递,效率低,效率低struct data int a, b, c; ;main() void func(struct data); struct data arg; arg.a=27; arg.b=3; arg.c=arg.a+arg.b; printf(arg.a=%d arg.b=%d arg.c=%dn,arg.a,arg.

24、b,arg.c); printf(Call Func().n); func(arg); printf(arg.a=%d arg.b=%d arg.c=%dn,arg.a,arg.b,arg.c);void func(struct data parm) printf(parm.a=%d parm.b=%d parm.c=%dn,parm.a,parm.b,parm.c); printf(Process.n); parm.a=18; parm.b=5; parm.c=parm.a*parm.b; printf(parm.a=%d parm.b=%d parm.c=%dn,parm.a,parm.b

25、,parm.c); printf(Return.n);例例 用结构体变量作函数参数用结构体变量作函数参数struct data int a, b, c; ;main() void func(struct data *parm); struct data arg; arg.a=27; arg.b=3; arg.c=arg.a+arg.b; printf(arg.a=%d arg.b=%d arg.c=%dn,arg.a,arg.b,arg.c); printf(Call Func().n); func(&arg); printf(arg.a=%d arg.b=%d arg.c=%dn,arg.a,arg.b,arg.c);void func(struct data *parm) printf(parm-a=%d parm-b=%d parm-c=%dn,parm-a,parm-b,parm-c); printf(Process.n); parm-a=18; parm-b=5; parm-c=parm-a*parm-b; printf(parm-a=%d parm-b=%d parm-c=%dn,parm-a,parm-b,parm-c);

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论