博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
第九章 结构体与共用体
阅读量:5347 次
发布时间:2019-06-15

本文共 4510 字,大约阅读时间需要 15 分钟。

C程序设计实验报告

实验项目:

1、结构体变量的应用

2、结构体数组的应用
3、共用体的应用
4、结构体指针的应用

姓名:杨婷  实验地点:514教室  实验时间:2019.6.26

一、本章要点

1、定义结构体类型的变量,要从键盘输入初值;

2、输入错误时,调用abort()函数退出程序,要包含头文件stdlib.h;
3、调用strcmp()函数进行字符串的比较;
4、结构体类型为构造数据类型时,应先定义类型,然后再定义该类型的变量;
5、结构类型的定义可以嵌套,结构类型与联合类型的定义也可以嵌套,只是要注意被嵌套的类型必须先有定义。

二、实验目的与要求

9.3.1 结构体变量的应用

1、定义结构体类型struct date,它含有年、月、日3个成员;
2、定义struct date类型的变量,并从键盘输入初值;
3、利用循环语句,计算天数;
4、利用分支结构,判断闰年。

9.3.2 结构体数组的应用

1、定义候选人struct person结构体数组,含有姓名、得票数两个成员;
2、定义struct person结构体数组,人数自定,初始票数为0;
3、利用循环输入候选人名字,该人员票数加1;
4、输入的候选人不是规定的候选人时,相当于废票,不累计。

9.3.3 共用体的应用

1、定义结构体类型,其成员有编号、姓名、职业和班级(或职务);
2、定义该结构体类型的数组,可有若干个数组元素;
3、利用该循环语句输入每条记录的数据,若该记录的职业为‘s’,则该记录是学生,输入该学生的班级;若该记录的职业是’t‘,则该记录是教师的,输入该教师的职务;
4、根据记录的职业来判断,使用哪个printf()语句输出记录。

9.3.4 结构体指针的应用

1、定义结构体类型,其成员有人员编号、下一人员编号(地址);
2、定义该结构体类型的数组,可有n个数组元素;
3、n个人围成一圈,可以考虑用结构体数组元素中的“下一人员编号”来实现,但最后一个元素的“下一人员编号”指向第一个。

三、实验内容

1、结构体变量的应用

<1>问题的简单描述:
试利用结构体类型描述年、月、日,输入一个日期,统计日期是本年度第多少天。
算法描述如图:
1616687-20190629153052798-1434214538.png
<2>实验代码:

#include
main(){ struct date { int year;int month;int day; /*含有年、月、日三个成员*/ }; struct date a; /*定义结构体变量a*/ int i,days=0; /*定义其他变量*/ printf("输入年,月,日:"); /*提示“输入年,月,日”*/ scanf("%d,%d,%d",&a.year,&a.month,&a.day); /*输入年,月,日*/ for(i=1;i

<3>运行结果:

1620901-20190630090758278-856533664.png
<4>问题分析:
问题:
1620901-20190630100604289-464728870.png
解决方法:
检查了几遍我的代码之后,发现“逻辑与”我只打了一个“&”,还有在判断闰年的表达式中我将取余符号打成了寻址符。
2、结构体数组的应用
<1>问题的简单描述:
在选举中,假设有6位候选人,有10个人参加投票(只能对一位候选人投票),用结构体数组统计各候选人的得票数。
算法描述如图:
1620901-20190630093958600-1486301280.png
<2>实验代码:

#include "stdio.h"#include 
struct person{ char name[20]; int count;}a[6]={"zhang",0,"li",0,"wang",0,"zhao",0,"liu",0,"zhu",0};main(){ int i, j; char abc[20]; for (i=1;i<=10;i++) { printf("输入候选人名字: "); /*提示“输入候选人名字”*/ scanf("%s",abc); /*输入候选人名字*/ for(j=0;j<6;j++) if(strcmp(abc,a[j].name)==0) a[j].count++; /*若第j个候选人名字与输入的名字相同,第j位候选人票数加1*/ } for (j=0;j<6;j++) printf("%s:%d\n",a[j].name,a[j].count); /*输出各候选人的名字和得票数*/}

<3>运行结果:

1620901-20190630093138091-496250264.png
<4>问题分析:
问题:
1620901-20190630102424987-156238053.png
输入完第一个候选人名字后,后面所有的“候选人名字”都出来了。
解决方法:
检查了代码之后发现在最后的printf()函数中输入的应该是a[j].name,而不是a[i].name。
3、共用体的应用
<1>问题的简单描述:
编写程序填写表格。从键盘输入学生和教师的信息,若是学生,则班级/职务栏填入班级;若是教师,则班级/职务栏填入职称。
算法描述如图:
1620901-20190630094042303-670340372.png
<2>实验代码:

#include
#include
/*包含头文件stdlib.h*/struct int number; char name[30]; char job; union { int classes; char position[10]; }category;}person[2];main(){ int i; for(i=0;i<2;i++) { printf("请输入编号、姓名、职业:"); /*输入某人的编号、姓名、职业*/ scanf("%d%s%s",&person[i].number,&person[i].name,&person[i].job); if(person[i].job=='s') { printf("请输入班级:"); scanf("%d",&person[i].category.classes); } else if(person[i].job=='t') { printf("请输入职务:"); scanf("%s",&person[i].category.position); /*输入教师的职称*/ } else { printf("input error!"); abort(); /*若输入错误,则退出程序*/ } } printf("\n"); printf("编号\t\t姓名\t\t职业\t\t班级/职务\n"); for(i=0;i<2;i++) { if(person[i].job=='s') { printf("%d\t\t",person[i].number); printf("%s\t\t",person[i].name); printf("%c\t\t",person[i].job); printf("%d\n",person[i].category.classes); /*输出学生的记录*/ } else { printf("%d\t\t",person[i].number); printf("%s\t\t",person[i].name); printf("%c\t\t",person[i].job); printf("%s\n",person[i].category.position); } }}

<3>运行结果:

1620901-20190630092316146-2091023947.png
<4>问题分析:
问题:
1620901-20190630105511751-1304998107.png
解决方法:
我按照书上的示例依次输入了姓名、编号、职业和职务,但实际上输入的顺序应该是编号、姓名、职业。
4.结构体指针的运用
<1>问题的简单描述:
n个人围成一圈,从第s个人开始按顺时钟1,2,3.....,m的顺序报数,数到m的人出圈,然后从出圈的下一个人开始重复此过程,输入所有出圈人的顺序。n,s,m从键盘输入。
算法描述如图:
1620901-20190630094140488-812712270.png
<2>实验代码:

#include
#define N 10 /**最多围圈人数/struct child{ int no; /*人员编号*/ int next; /*下一人员编号*/};struct child link[N]; /*定义结构体数组link[N],描述所有人员*/main(){ int i,n,m,s,count,h; /*定义变量*/ printf("输入围圈人数,出圈报数,开始报数位置:"); scanf("%d%d%d",&n,&m,&s); /*输入围圈人数n,出圈报数m,开始报数位置s*/ for(i=1;i<=n;i++) { if(i==n) link[i].next=1; else link[i].next=i+1; link[i].no=i; } count=0; if(s==1)h=n;else h=s-1; printf("出圈顺序为:"); while(count

<3>运行结果:

1620901-20190630092702959-570730213.png
<4>问题分析:
输出最后留在圈中人数时要用“link[i].name”。

四、实验小结

收获:

1.当输入错误时,调用abort()函数退出程序(void abort(void));
2.比较候选人的名字:strcmp(abc,a[j].name)==0;
(用比较运算符对两个枚举型变量或数组元素进行“大小”比较,可以按照变量或数组元素的枚举变量值(整数)的大小进行比较);
3.逻辑与要打两个取址符。
不足:
1.在打代码过程不够仔细,会打错一些符号;
2.总是按照书上的内容来做,但有时候书上的内容也会出错。

转载于:https://www.cnblogs.com/youthyee/p/11108738.html

你可能感兴趣的文章
解决VS+QT无法生成moc文件的问题
查看>>
AngularJs练习Demo14自定义服务
查看>>
关于空想X
查看>>
CF1067C Knights 构造
查看>>
[BZOJ2938] 病毒
查看>>
webstorm修改文件,webpack-dev-server不会自动编译刷新
查看>>
Scikit-learn 库的使用
查看>>
CSS: caption-side 属性
查看>>
python 用数组实现队列
查看>>
认证和授权(Authentication和Authorization)
查看>>
Mac上安装Tomcat
查看>>
CSS3中box-sizing的理解
查看>>
传统企业-全渠道营销解决方案-1
查看>>
Lucene全文检索
查看>>
awk工具-解析1
查看>>
推荐一款可以直接下载浏览器sources资源的Chrome插件
查看>>
CRM product UI里assignment block的显示隐藏逻辑
查看>>
AMH V4.5 – 基于AMH4.2的第三方开发版
查看>>
Web.Config文件配置之配置Session变量的生命周期
查看>>
mysql导入source注意点
查看>>