2014湖南大学c语言实验题目及其答案(4)
更新时间:2023-09-22 12:59:01 阅读量: 经管营销 文档下载
第四章 构造数据类型
一 目的和要求
1、掌握结构体类型说明和结构体类型变量、数组、指针的定义方法及使用。 2、学会引用结构体中的成员。
3、掌握利用指向结构体的指针成员构成链表的基本算法。
4、了解联合体类型和枚举类型的说明、其变量的定义及赋初值的方法。 5、了解联合类型变量中各成员的存储结构,学会引用各成员中的数据。 6、学习正确引用枚举类型常量,了解如何对枚举类型变量进行操作。
二 相关知识
1、结构型变量的定义和引用
构造类型是由相同或不同的数据类型组合而成。用户自己定义的一种用来存放类型不同的数据的数据类型,称为结构型。 ⑴ 结构型的定义
struct <结构体名> { 类型1 成员名1; 类型2 成员名2; …
类型n 成员名n; };
结构型是一种数据类型,其中的成员不是变量,系统不会给成员分配内存。已经定义的某种结构型可以作为一种数据类型,用来定义变量、数组、指针,这时才会给定义的变量、数组、指针分配内存。 ⑵ 结构型变量的定义
有三种方法:先定义结构型,然后定义变量、数组;同时定义结构型和变量、数组;定义无名称的结构型同时定义变量、数组。 ⑶ 结构型变量的引用
当某种结构型的变量、数组被定义后,对其只能使用其中的成员,常见的引用方法如下:
① 结构型变量、数组元素成员的引用
结构型变量名?成员名
或
结构型数组名[下标] ?成员名
② 结构型变量、数组元素成员地址的引用
&结构型变量名?成员名
或
&结构型数组名[下标] ?成员名 ③ 结构型变量、数组元素地址的引用
&结构型变量名
或
&结构型数组名[下标]
结构型数组首地址的引用: 结构型数组名
2、共用型
共用型数据中所有成员占用相同的内存单元,设置这种数据类型的主要目的就是节省内存。
⑴ 共用型的定义
union <共用体名>
{ 类型1 成员名1; 类型2 成员名2; …
类型n 成员名n; };
共用型中每个成员所占用的内存单元都是连续的,而且都是从分配的连续内存单元中第一个内存单元开始存放,共用体所占的内存长度等于最长的成员的长度。所以,对共用型数据来说,所有成员的首地址都是相同的。 ⑵ 共用型变量的定义
有三种方法:先定义共用型,然后定义变量、数组;同时定义共用型和变量、数组;定义无名称的共用型同时定义变量、数组。
特别注意的是:由于共用型数据的成员不能同时起作用,每一瞬时只能存放其中的某一个成员的数据。因此,对共用型变量、数组定义不能赋初值,只能在程序中对其成员赋值。
⑶ 共用型变量的引用
对共用型变量、数组的引用和对结构型变量、数组的引用方法和要求基本相同。 关于共用型,C语言还有一个重要的规定,共用型数据不能作为函数的参数在函数间传递,也不可以定义某函数返回共用型数据值。但是,允许使用指向共用型数据的指针变量在函数间传递共用型数据。
3、枚举型
将一个有限的变量值一一列举出来称为枚举。 ⑴ 枚举型的定义
enum <枚举类型名> {<枚举常量1>,<枚举常量2>,…}[<枚举变量1>,…]; 说明:在定义时若无特别指定,“枚举常量1”的值为0,其余依次序加1递增。C语言规定,在定义枚举类型时,可以给枚举常量赋初值,方法是在枚举常量的后面写上“=整型常量”,如果给某一个枚举常量赋初值,则其后的枚举常量将按自然数的规则依次赋初值。
⑵ 枚举型变量、数组的定义
有三种方法:先定义枚举类型,然后定义变量、数组;同时定义枚举类型和变量、数组;定义无名称的枚举类型同时定义变量、数组。 ⑶ 枚举型变量的引用
① 给变量或数组元素赋值,格式为:
枚举型变量或数组元素=同一枚举常量名
② 用比较运算符对两个枚举型变量或数组元素进行“大小”比较,可以按照变量或数组元素的枚举常量值(整数)的大小进行。
③ 枚举型变量或数组元素可以进行“自增++”和“自减--”运算。 ④ 可以在循环中用枚举型变量或数组元素控制循环。
4、用户自定义类型
定义新的类型名来代替已有的类型称为用户自定义类型。其格式为: typedef 原类型名 新类型名
用typedef可以为已存在的各种类型增加一个类型名。
三 实验练习
实验练习 1:试利用结构体类型编写程序,有5个职工的姓名、基本工资和补贴,计算每个职工的实发工资并输出。
本练习要求在封闭式实验课中在助教或者讲师的指导下完成。本练习分成6个部分: 1. 实验目的 2. 问题描述 3. 事例输出 4. 程序模板 5. 问题解答提示 6. 后续问题和任务
程序模板是完整的、可实际运行的C程序,其中关键的一行或者多行代码已经替换为注释。请先阅读问题描述,分析事例输出;然后研究模板的代码。参考问题解答提示,用C代码替换/* */注释。编译并执行程序,并将输出结果与提供的事例输出进行比较。然后回答强化练习。 实验目的:
本实验旨在巩固学生对结构体这种数据结构概念的理解,增强程序设计能力。在这个实验中,学生将练习:
? 定义结构体类型struct worker,它含有四个成员:姓名、基本工资、补贴和实发工资。
? 定义struct worker类型的数组,它有五个数组元素并赋予了初值。 ? 利用循环语句,计算每个人的实发工资。
? 利用循环语句,输出每个人的姓名和实发工资。 在强化练习中,学生将练习:
? 不给struct worker类型的数组赋初值,利用循环语句从键盘逐个输入数据。 ? 增加几个变量,将所有人的基本工资、补贴和实发工资累加起来,并输出。 问题描述
编写程序,定义一个结构体类型的数组,存有5个职工的姓名、基本工资和补贴,计算每个职工的实发工资并输出。 示例输出:
li 2120.0 ma 2065.0 lin 3445.0 wang 5467.0 deng 7328.0 程序模板
#include \void main( ) { int i;
/*结构体类型struct worker的定义,其成员有姓名、基本工资、补贴和实发工资*/
struct worker s[5]={{\
{\for(i=0;i<5;i++)
/*计算每个人的实发工资*/ for(i=0;i<5;i++)
/*用printf()语句输出每个人的姓名和实发工资*/
}
问题解答提示
1.结构体类型是构造数据类型,应先定义类型然后再定义该类型的变量、数组等。结构体类型的定义可放在函数体内或函数体外。
2.结构体类型是由相同或不同的数据类型组合而成,所以结构体数组的每个数组元素可以看作为一条记录。
3.对结构体数组赋初值是用一对花括号将数据括起来,其中每条记录的数据再用一对花括号括起来。
4.每个人的实发工资计算,是他的基本工资加上补贴。这里实发工资、基本工资和补贴要用结构体的成员表示方法以说明是属于哪个人的。
5.在输出语句printf(\ %6.1f\\n\中,\ %6.1f\是将姓名左对齐输出,实发工资右对齐输出。
6.不能将记录作为一个整体输出,而应分别输出记录的各个数据项。 7.如果在实验中碰到任何问题,请向实验老师寻求帮助。
强化练习
1.根据程序模板,利用循环语句从键盘逐个输入数据,给struct worker类型的数组元素赋值。 2.重新编写程序,增加几个变量,将所有人的基本工资、补贴和实发工资累加起来,并输出。
实验练习 2:假设一个患者的病史数据中包含了患者姓名、性别、年龄、初诊日期、复诊日期等数据,试用嵌套结构体的方法,编写程序输入、输出某个患者的病史情况。如下表: 姓名
本练习要求在封闭式实验课中在助教或者讲师的指导下完成。本练习分成6个部分: 1. 实验目的 2. 问题描述 3. 事例输出 4. 程序模板 5. 问题解答提示 6. 后续问题和任务
性别 年龄 初诊日期 年 月 日 复诊日期 年 月 日
程序模板是完整的、可实际运行的C程序,其中关键的一行或者多行代码已经替换为注释。请先阅读问题描述,分析事例输出;然后研究模板的代码。参考问题解答提示,用C代码替换/* */注释。编译并执行程序,并将输出结果与提供的事例输出进行比较。然后回答强化练习。
实验目的:
本实验旨在巩固学生对结构体这种数据结构概念的理解,增强程序设计能力。在这个实验中,学生将练习:
? 定义日期struct date结构体,含有成员:年、月、日。
? 定义患者struct patient结构体,含有姓名、性别、年龄、初诊日期和复诊日期,初、复诊日期是struct date类型的数据。 ? 定义设置日期函数getdate(),得到某个日期。 ? 定义struct patient类型的变量a。
? 分别输入患者a的姓名、性别、年龄、初诊日期和复诊日期。 ? 输出该患者a的姓名、性别等信息。
在强化练习中,学生将练习:
? 将设置日期函数getdate()的类型设为struct date类型。
? 定义struct patient类型的数组,对一组病人的信息进行处理。
问题描述
编写程序,输入、输出某个患者的病史情况。患者的病史情况包括姓名、性别、年龄、初诊日期和复诊日期。
示例输出(数据自拟) 请输入姓名: liming 请输入性别: m 请输入年龄: 33 请输入初诊日期: 2003 5 19 请输入复诊日期: 2004 4 8 姓名:liming 性别:m 年龄:33 初诊日期:2003.5.19 复诊日期:2004.4.8
程序模板
#include \struct date {
int year, month, day;
};
/*定义患者struct patient结构体,含有成员:姓名、性别、年龄、初诊日期和复诊日期*/
/*定义设置日期getdate()函数,从键盘分别输入年、月、日*/ void main( ) {
/*定义struct patient类型的变量a*/ printf(\请输入姓名:\/*输入患者的姓名*/ printf(\请输入性别:\scanf(\printf(\请输入年龄:\scanf(\
/*提示\请输入初诊日期:\getdate(&a. first);
printf(\请输入复诊日期:\/*得到复诊日期*/
printf(\姓名: %s\printf(\性别: %c\/*输出年龄*/
/*输出患者的初诊日期*/
printf(\复诊日: %d.%d.%d\printf(\}
问题解答提示
1.struct patient类型的成员中有struct date类型的数据,所以struct date类型的定义要在struct patient类型的定义之前。
2.设置日期getdate()函数的类型是 void(无值类型),所以调用是写成调用语句形式。
3.调用设置日期getdate()函数时,如:getdate(&a. first),实参是取患者a的初诊日期的地址,所以其形参应该是struct date类型的指针。 4.指向结构体变量的指针的成员表示是用指向运算符”―>”。如在设置日期getdate()函数中输入”年”可写成scanf(“%d”,&d->year);,假设形参是struct date *d。 5.用gets(a.name)输入患者的姓名,这时空格也可作为患者姓名的一部分。
6.在输出患者的初诊日期时,如输出年份时,应写成:a.first.year。即变量a的first成员的yaer成员。
7.结构体的嵌套,可以完成表(1)这样的数据结构。 8.如果在实验中碰到任何问题,请向实验老师寻求帮助。
强化练习
1.根据程序模板,将设置日期函数getdate()的类型设为struct date类型,重新编写程序。
2.重新编写程序,定义struct patient类型的数组,对一组病人的信息进行处理
实验练习 3:若将教师和学生的数据放在同一表格中。教师的数据包括:编号、姓名、职业和职务,学生的数据包括:编号、姓名、职业和班级。试编写程序填写表格。如下表: 编号 10011 20001 姓名 liming wangli 职业 s t 职务 班级 201 讲师 本练习要求在封闭式实验课中在助教或者讲师的指导下完成。本练习分成6个部分: 1. 实验目的 2. 问题描述 3. 事例输出 4. 程序模板 5. 问题解答提示 6. 后续问题和任务
程序模板是完整的、可实际运行的C程序,其中关键的一行或者多行代码已经替换为注释。请先阅读问题描述,分析事例输出;然后研究模板的代码。参考问题解答提示,用C代码替换/* */注释。编译并执行程序,并将输出结果与提供的事例输出进行比较。然后回答强化练习。
实验目的:
本实验旨在巩固学生对结构体这种数据结构概念的理解,增强程序设计能力。在这个实验中,学生将练习:
? 定义结构体类型,其成员有:编号、姓名、职业和班级(或职务)。 ? 定义该结构体类型的数组,可有若干个数组元素。
? 利用循环语句输入每条记录的数据,若该记录的职业为’s’,则该记录是学生的,输入该学生的班级;若该记录的职业为’t’,则该记录是教师的,输入该教师的职务。
? 根据记录的职业来判断,使用哪个printf()语句输出记录。
在强化练习中,学生将练习:
? 将编号定义为字符型,若规定编号的第一个字符为‘0’则表示学生,为‘1’则表示教师。
? 将输入部分和输出部分独立出来,编成函数。
问题描述
编写程序填写表格。从键盘输入学生和教师的信息,若是学生则班级/职称栏填入班级,若是教师则班级/职称栏填入职称。
示例输出
10011 liming s 201 20001 wangli t 讲师 编号 姓名 职业 班级/职务 10011 liming s 201 20001 wangli t 讲师
程序模板
#include \
/*包含头文件stdlib.h*/ struct
{ int number; char *name; char job; union
{ int classes;
char position[10]; }category;
}person[2]; void main() { int i;
for(i=0;i<2;i++)
{ /*输入某人的编号、姓名、职业*/ if(person[i].job=='s')
scanf(\ else if(person[i].job=='t') /*输入教师的职称*/
else
{ printf(\
/*若输入错误,则退出程序*/ } }
printf(\
printf(\编号 姓名 职业 班级/职务\\n\ for(i=0;i<2;i++)
if(person[i].job=='s') /*输出学生的记录*/ else
printf(\ %s %c %s\\n\
person[i].job,person[i].category.position);
}
问题解答提示
1.定义结构体时没有给出结构体名,所以要同时定义结构体变量和数组。
2.共用体变量在这作为结构体的成员出现,如person[0]是结构体类型的数组元素,它的category成员是共用体类型的变量。 3.category成员可以取两种值:整型值和字符型值,当person[0].job是’s’时,category成员取数值型数据,表示为person[0]. category.classes,当person[0].job是’t’时,category成员取字符型数据,表示为person[0]. category.position。 4.结构体和共用体的组合,可以完成表(2)这样的数据结构。
5.若输入错误,则调用abort()函数退出程序。这时要包含头文件stdlib.h。 6.如果在实验中碰到任何问题,请向实验老师寻求帮助。
强化练习
1.重新定义结构体,去掉成员job(职业),将numbre(编号)定义为字符型,若规定编号的第一个字符为‘0’则表示学生,为‘1’则表示教师。试编写程序。 2.将输入部分和输出部分独立出来编成函数,重新编写程序。
9.4 综合练习
1.定义一个结构体类型,包含用户的姓名(含6个字符的字符串)和电话号码(含8个字符的字符串)。编写函数用于读入N位用户的数据到结构数组中;编写函数用于将数组中的用户按姓名的字母顺序重新排列;编写函数用于输出数据。
分析:需说明包含姓名及电话号码两个成员的用户类型struct USER,由于字符串总以’\\0’为结束标志,因而应定义合适的数组长度。
main()函数中定义一个结构体数组user,用于存放 N位用户的数据。函数getUser用于读取 N位用户的数据并存入user数组中;函数sortUser用于将user数组中的N位用户按其姓名的字母顺序重新排列;函数outUser用于将重新排序后user数组输出。
#include \#include \#define N 5 struct USER
{ char name[7],tel[9]; }; void getUser(USER *p,int n) { int i;
printf(\请输入所有用户的姓名和电话号码:\\n\ for(i=0;i void sortUser(USER *p,int n) { int i,j,k; USER temp; for(i=0;i for(j=i+1;j { temp=p[k]; p[k]=p[i]; p[i]=temp; } } } void outUser(USER *p,int n) { int i; for(i=0;i void main() { USER user[N]; getUser(user,N); sortUser(user,N); outUser(user,N); } 2.设单链表结点类型node定义如下: struct node { int data; struct node *next; }; 编写程序,将单链表A和单链表B合并成一个单链表C。 /*sy9_4.c*/ #include \#include \struct node { int data; struct node *next; }*head,*head1,*head2; void main( ) { int i; struct node *p,*q,*p1,*q1; head1=NULL; for(i=2;i<=10;i+=2) { p=(struct node *)malloc(sizeof(struct node)); p->data=i; p->next=head1; head1=p; } head2=NULL; for(i=1;i<10;i+=2) { p=(struct node *)malloc(sizeof(struct node)); p->data=i; p->next=head2; head2=p; } p=head1; while(p!=NULL) { printf(\ p=p->next; } printf(\ p=head2; while(p!=NULL) { printf(\ p=p->next; } printf(\ head=head1; p=head1; q=head2; while(p!=NULL) { p1=p->next; q1=q->next; p->next=q; q->next=p1; p=p1; q=q1; } p=head; while(p!=NULL) { printf(\ p=p->next; } printf(\ }
正在阅读:
2016-2022年中国五金制品市场专题研究分析与发展前景预测报告08-28
清华书单08-28
基础会计学知识点总结08-28
【K12教育学习资料】高中数学第三章指数函数对数函数和幂函数3.2对数函数3.2.2对数函数自主训练08-28
HCNA-WLAN题库 - 图文04-09
2018年中国社区信息化市场研究及发展趋势预测(目录)08-29
- 教育局拟征求中考升学奖励制度
- 2020房地产销售主管年终工作总结
- 虚拟多台位互感器检定装置投资项目可行性分析
- 车间工人辞职报告范本
- 溴投资项目可行性分析
- 改名字申请书怎么写
- 忧与爱作文素材
- 溴苯腈投资项目可行性分析
- 2020清华大学考研复试时间:3月6日至22日
- 2020年蚌埠高考查分系统网址
- 2020年二建《建筑工程实务》测试题及答案(13)
- 生死感悟——人间世观感一
- 武陵源区军地小学观看魏书生《如何当好班主任》讲座录像
- 全球10大安全旅游国出炉日本排名第9
- 企业策划书模板
- 高中英语教师工作总结3篇
- 法定代表人证明范本
- 大学助学金申请书范文1700字
- 案外人申请不予执行仲裁裁决司法解释施行首份申请书递交齐齐哈尔...
- 环球国际房地产开发项目策划
- 湖南大学
- 题目
- 答案
- 及其
- 语言
- 实验
- 2014
- 最新冀教版小学英语四年级上册Unit 3 Lesson 13 At School 公开课教学设计1
- 《微机原理及应用》期末考试复习参考资料
- 德州扑克经验技巧跟心得
- 幼儿园园长管理案例
- 联梁型钢悬挑脚手架计算书(小横杆排脚手架,横杆与立杆连接方式为单扣件,连墙件扣件连接方式为双扣件)
- Unit1 翻译
- 微机接口课设-步进电机控制系统设计
- 沪科版生命科学高一上3-2《细胞核和细胞器》讲义 - 图文
- 小学生的家庭教育
- 自动检测复习题
- 组成原理复习题2014浦计12new
- 金蝶常见问题及处理方法
- 2018-2019年小学语文人教版《一年级上》《第五组》《12. 雨点儿》课后练习试卷含答案
- 高中语文选修课的教学与反思
- 中国布料服装行业发展研究报告 - 图文
- 2018-2019学年新课标最新冀教版小学语文三年级上册《木偶奇遇记》教学设计-精品教案
- 内分泌学科发展规划
- 整百、整千数的加减法的教学反思
- 哈工大机械原理大作业 凸轮机构 32
- 全国大纲版2013届高三高考压轴数学(文)试题(二)