标签:结构体类型 结果 地址 数加 函数 zha 程序设计 fine 设计
结构类型的定义可以嵌套,结构类型与联合类型的定义也可以嵌套,只是要注意被嵌套的类型必须先有定义。
利用分支结构,判断闰年。
输入的候选人不是规定的候选人时,相当于废票,不累计。
根据记录的职业来判断,使用哪个printf()语句输出记录。
n个人围成一圈,可以考虑用结构体数组元素中的“下一人员编号”来实现,但最后一个元素的“下一人员编号”指向第一个。
#include<stdio.h>
main()
{
struct date
{
int year;
int month;
int day;
};
struct date 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||i==12)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);
}
程序运行如下:
#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++;
}
for(j=0;j<6;j++)
printf("%s,%d\n",a[j].name,a[j].count);
}
3问题分析:(重点分析在实验过程中出现的问题,及解决方法。)
这道题需要用到strcmp()比较函数进行比较来判断该候选人的票数是否要加1,若输入姓名与给定候选人名字相等,则对于的票数加1;若不相等,则为废票。
程序运行如下:
#include<stdio.h>
#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++)
{
fflush(stdin);
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%s\t\t%c\t\t%d\n",person[i].number,person[i].name,person[i].job,person[i].category.classes);
else
printf("%d\t\t%s\t\t%c\t\t%s\n",person[i].number,person[i].name,person[i].job,person[i].category.position);
}
程序运行结果如下:
#include<stdio.h>
#define N 10
struct child
{
int no;
int next;
};
struct child link[N];
main()
{
int i,n,m,s,count,h;
printf("输入围圈人数:出圈报数,开始报数位置:");
scanf("%d,%d,%d",&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)
{
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);
}
程序运行结果如下:
这节实验课进行的是关于结构体和共用体的一些相关实验,让我对结构体类型变量、数组、指针的定义有了进一步的了解,学会了怎么引用结构体中的成员,知道了结构体中数组变量的输入可以不使用‘&’取地址运算符,怎么在结构体中嵌套使用函数定义,在输出的时候要逐级输入结构体名称。
标签:结构体类型 结果 地址 数加 函数 zha 程序设计 fine 设计
原文地址:https://www.cnblogs.com/luolongmei/p/11108961.html