实验11 结构体、共用体和枚举类型
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
实验11 结构体、共用体和枚举类型
一、实验目的:
1、掌握结构体类型定义和结构体变量定义、初始化的方法;
2、掌握结构体成员的访问方法,熟悉结构体嵌套定义方法;
3、掌握结构体数组的定义和使用方法,能够用模块化方法设计程序;
4、熟悉共用体类型、枚举类型、typedef的基本用法。
二、实验内容
1、(基础题)下列程序的功能是:先定义结构体Book,再定义两个变量book1、book2,其中一个初始化,另一个从键盘输入数据,最后输出book1、book2的值。程序运行结果如下:
请根据题意和注释填写下列程序所缺代码,并回答相关问题:
#include
//定义结构体Book,成员有:书名(title),字符数组,长度为100;
//作者(authors),字符数组,长度为30;ISBN,字符数组,长度为20;
//页数(pages),整型;价格(price),单精度浮点数。
/*代码段_1*/
struct Book
{
char title[100];
int main()
{
//定义两个Book型变量book1、book2,其中book1用我们本学期所使用教材的数据初始化
/*代码段_2*/
//从键盘输入我们本学期所使用实验指导书的数据给book2
/*代码段_3*/
printf("请输入实验指导书的信息:书名、作者、ISBN、页数、作者:\n");
/*代码段_4*/
printf("\n教材、实验书信息如下:\n");
/*代码段_5*/
return 0;
}
问题:
(1)如何定义结构体类型?
(2)怎样定义结构体变量,并初始化?
(3)怎样输入、输出结构体变量各成员的值?
2、(基础题)请按下列要求编程:
(1)先定义一个结构体Date,它包含三个成员:年(year,int)、月(month,int)、日(day,int);
(2)再定义一个结构体,它包含三个成员:姓名(name,char[10])、性别(sex,char类型,’m’为男,’f’为女)、出生时间(birthday,Date类型)、身份证号(ID,char[19])、电子邮箱(email,char[60]),并用typedef将该结构体命名为Person类型;
(3)然后定义一个Person类型的变量me,通过键盘输入自己的信息,然后输出me的各成员值。
程序执行如下图所示:
(提示:由于输入内容有字符串、字符、整数等,建议在scanf()中的格式控制符用空格隔开,例如scanf("%s %c %d %d %d %s %s",,…);)
3、(基础题)学生有三门课程:A、B、C,3名学生的成绩如下表所示:
请先定义一个结构体Student,其成员包括:name(姓名)、A、B、C、aver(平均分),再定义一个Student类型的数组stud[3]来存放学生资料。现欲先输入学生三门课程成绩,再计算平均分,最后输出学生信息,要求用“模块化程序设计”方法来设计程序。请根据题意、注释在代码段1-代码段5中填写程序所缺代码。
#include
//定义结构体Student,学生姓名不超过10个字符
//三门课程成绩均为百分制,只取整数;平均分带小数
struct Student
{
//代码段1
};
int main()
{
//定义结构体数组stud[3]
//对input()、average()、print()三个函数进行声明
//调用input()、average()、print()三个函数
//代码段2
return 0;
}
//定义输入n名学生的姓名、三门课程成绩的函数。
void input(Student s[], int n)
{
//代码段3
printf("\n");
}
输入某一学生成绩的界面如下:
//定义计算n名学生三门课程平均分的函数
void average(Student s[], int n)
{
//代码段4
}
//定义输出n名学生的姓名、三门课程成绩、平均分的函数。学生信息输出如下图所示
void print(Student s[], int n)
{
//代码段5
printf("\n");
}
输出结果界面如下:
4、(提高题)共用体的使用:
几个不同的变量共享同一段内存的结构称为共用体,当然这几个变量不能同时存放,在每一瞬时只能存放其中一个变量。如果换一个角度来看,也可以把同一个数,当做不同类型来看待,输出结果也不同。
我们知道VC++中,float型数据与unsigned int都占用4字节,但它们的存储形式不同,可以利用共用体,给它赋予一个float型数据,再将它看作是一个unsigned int数据来输出(用十六进制表示),以观察float数据存储是否与理论值一致?浮点数的存储格式见《IEEE754标准.doc》文档。并回答相关问题:#include
int main()
{
union
{
float r;
unsigned int n;
}x;
x.r=178.125;
printf("float型数据: %f 存储数据与unsigned int: %X H相同。
\n\n",x.r,x.n);
return 0;
}