标签:struct 第九章 name int 共用 描述 include 输入 结构
C程序设计实验报告
实验项目:
1、结构体变量的应用
2、结构体数组的应用
3、共用体的应用
4、结构体指针的应用
姓名:杨婷 实验地点:514教室 实验时间:2019.6.26
一、本章要点
1、定义结构体类型的变量,要从键盘输入初值;
2、输入错误时,调用abort()函数退出程序,要包含头文件stdlib.h;
3、调用strcmp()函数进行字符串的比较;
4、结构体类型为构造数据类型时,应先定义类型,然后再定义该类型的变量。
二、实验内容
1、结构体变量的应用
<1>问题的简单描述:
试利用结构体类型描述年、月、日,输入一个日期,统计日期是本年度第多少天。
算法描述如图:
<2>实验代码:
#include<stdio.h>
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<a.month;i++)
{
if(i==1||i==3||i==5||i==7||i==8||i==10)
days+=31;
else if(i==4||i==6||i==9||i==11)
days+=30;
else if((a.year%4==0&&a.year%100!=0)||a.year%400==0)
days+=29;
else days+=28;
}
days+=a.day;
printf("%d年%d月%d日是该年的第%d天",a.year,a.month,a.day,days);
} /*输出结果*/
<3>运行结果:
<4>问题分析:
问题:
解决方法:
检查了几遍我的代码之后,发现“逻辑与”我只打了一个“&”,还有在判断闰年的表达式中我将取余符号打成了寻址符。
2、结构体数组的应用
<1>问题的简单描述:
在选举中,假设有6位候选人,有10个人参加投票(只能对一位候选人投票),用结构体数组统计各候选人的得票数。
算法描述如图:
<2>实验代码:
#include "stdio.h"
#include <string.h>
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>运行结果:
<4>问题分析:
问题:
输入完第一个候选人名字后,后面所有的“候选人名字”都出来了。
解决方法:
检查了代码之后发现在最后的printf()函数中输入的应该是a[j].name,而不是a[i].name。
3、共用体的应用
<1>问题的简单描述:
编写程序填写表格。从键盘输入学生和教师的信息,若是学生,则班级/职务栏填入班级;若是教师,则班级/职务栏填入职称。
算法描述如图:
<2>实验代码:
#include<stdio.h>
#include<stdlib.h> /*包含头文件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>运行结果:
<4>问题分析:
问题:
解决方法:
我按照书上的示例依次输入了姓名、编号、职业和职务,但实际上输入的顺序应该是编号、姓名、职业。
4.结构体指针的运用
<1>问题的简单描述:
n个人围成一圈,从第s个人开始按顺时钟1,2,3.....,m的顺序报数,数到m的人出圈,然后从出圈的下一个人开始重复此过程,输入所有出圈人的顺序。n,s,m从键盘输入。
算法描述如图:
<2>实验代码:
#include<stdio.h>
#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<n-1) /*出圈人数<围圈人数-1*/
{
i=0;
while(i!=m)
{
h=link[h].next;
if(link[h].no)
i++;
}
printf("%d, ",link[h].no);
link[h].no=0;
count++;
}
for(i=1;i<=n;i++)
{
if(link[i].no!=0)
printf("%d",link[i].no); /*输出最后留在圈中人数*/
}
}
<3>运行结果:
<4>问题分析:
输出最后留在圈中人数时要用“link[i].name”。
三、实验小结
收获:
1.当输入错误时,调用abort()函数退出程序(void abort(void));
2.比较候选人的名字:strcmp(abc,a[j].name)==0;
(用比较运算符对两个枚举型变量或数组元素进行“大小”比较,可以按照变量或数组元素的枚举变量值(整数)的大小进行比较);
3.逻辑与要打两个取址符。
不足:
1.在打代码过程不够仔细,会打错一些符号;
2.总是按照书上的内容来做,但有时候书上的内容也会出错。
标签:struct,第九章,name,int,共用,描述,include,输入,结构 来源: https://www.cnblogs.com/youthyee/p/11108738.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。