2结构体相关题目
2016-06-08 本文已影响1116人
Micason
1.需要定义结构体
Paste_Image.png#include <stdio.h>
struct date
{
int year;
int month;
int day;
};
int leap_year(int a);
int cal_day(struct date a);
int leap_year(int a)
{
if(a%400==0||(a%4==0&&a%100!=0))
return 1;
else
return 0;
}
int cal_day(struct date a)
{
int i=0;
int sum=0;
int b[]={31,28,31,30,31,30,31,31,30,31,30,31};
for(i=0;i<a.month-1;i++)
sum+=b[i];
if(a.month>2)
sum=sum+a.day+leap_year(a.year);
else
sum=sum+a.day;
return sum;
}
void main()
{
struct date a;
int n;
scanf("%d%d%d",&a.year,&a.month,&a.day);
n=cal_day(a);
printf("%d\n",n);
}
2.
Paste_Image.png现有有N个学生的数据记录,每个记录包括学号、姓名、三科成绩。编写一个函数input,用来输入一个学生的数据记录。编写一个函数print,打印一个学生的数据记录。在主函数调用这两个函数,读取N条记录输入,再按要求输出。 N<100【考虑用什么做函数的参数?结构体变量,还是指向结构体的指针变量,还是用结构体数组名?】
#include<stdio.h>
struct student{
char num[20];
char name[20];
int score[3];
};
void input(struct student a[],int n)
{
int i;
for (i=0;i<n;i++)
scanf("%s%s%d%d%d",&a[i].num,&a[i].name,&a[i].score[0],&a[i].score[1],&a[i].score[2]);
}
void print(struct student a[],int n)
{ int i;
for (i=0;i<n;i++)
printf("%s,%s,%d,%d,%d\n",a[i].num,a[i].name,a[i].score[0],a[i].score[1],a[i].score[2]);
}
int main()
{
struct student a[4];
int n,i;
scanf("%d",&n);
input(a,n);
print(a,n);
}
3.
Paste_Image.png有N个学生,每个学生的数据包括学号、姓名、3门课的成绩,从键盘输入N个学生的数据,要求打印出3门课的总平均成绩,以及最高分的学生的数据(包括学号、姓名、3门课成绩)
注意:刻画学生的数据类型必须用结构体类型。不能用多个数组解决
#include<stdio.h>
#define t 100
struct sta
{
char xh[20];
char name[20];
double x1;
double x2;
double x3;
};
void input(int n,struct sta*);
void output(int n,struct sta *);
int main()
{
int m,i;
struct sta cj[t];
scanf("%d",&m);
input(m,cj);
output(m,cj);
return 0;
}
void input(int n,struct sta *cj)
{
int i;
for(i=0;i<n;i++)
{
scanf("%s",&cj[i].xh);
scanf("%s",&cj[i].name);
scanf("%lf",&cj[i].x1);
scanf("%lf",&cj[i].x2);
scanf("%lf",&cj[i].x3);
}
}
void output(int n,struct sta *cj)
{
int i,t1;
double sum1=0,sum2=0,sum3=0,s=0,max,a,b,c;
for(i=0;i<n;i++)
{
sum1+=cj[i].x1;
sum2+=cj[i].x2;
sum3+=cj[i].x3;
}
max=cj[0].x1+cj[0].x2+cj[0].x3;
t1=0;
for(i=0;i<n;i++)
{
s=cj[i].x1+cj[i].x2+cj[i].x3;
if(s>max)
{
max=s;
t1=i;
}
}
a=sum1/n;b=sum2/n;c=sum3/n;
printf("%.0f %.0f %.0f",a,b,c);
printf("\n");
printf("%s ",cj[t1].xh);
printf("%s ",cj[t1].name);
printf("%.0f ",cj[t1].x1);
printf("%.0f ",cj[t1].x2);
printf("%.0f",cj[t1].x3);
}
Paste_Image.png建立一个学生情况登记表,包括学号、姓名、5门课成绩。编写程序实现以下功能:
1、输入n(n<=40)个学生的数据(不包括总分)
2、计算每个学生的总分
3、按每个学生总分由高到低排序
4、由键盘输入一个学号,输出给定学号的学生的所有信息
#include "stdio.h"
struct student /*定义表示学生信息的结构体类型student*/
{
int num; /*学号*/
char name[10]; /*姓名*/
int grade[5]; /*五门课程的成绩*/
int sum; /*总分*/
};
void input(struct student *a, int n) /*输入学生信息的函数,以一个student类型的数组和一个整形变量为形参*/
{
int k; /*计数变量*/
for(k=0; k<n; k++) /*赋值*/
scanf("%d%s%d%d%d%d%d", &a[k].num, a[k].name, &a[k].grade[0], &a[k].grade[1],
&a[k].grade[2], &a[k].grade[3], &a[k].grade[4]);
}
void sum(struct student *a, int n) /*求五科成绩之和的函数*/
{
int k;
for(k=0; k<n; k++)
a[k].sum=a[k].grade[0]+a[k].grade[1]+a[k].grade[2]+a[k].grade[3]+a[k].grade[4];
}
void change(struct student *a, int n)
{
int i, k;
struct student temp; /*暂时的存储变量*/
for(i=0; i<n; i++) /*使用冒泡排序法*/
for(k=0; k<n-1; k++)
if(a[k].sum<a[k+1].sum)
temp=a[k], a[k]=a[k+1], a[k+1]=temp;
for(k=0; k<n; k++)
printf("%d %s %d %d %d %d %d %d\n", a[k].num, a[k].name, a[k].grade[0], a[k].grade[1],
a[k].grade[2], a[k].grade[3], a[k].grade[4], a[k].sum);
}
void output(struct student *a, int n, int num)
{
int k;
for(k=0; k<n; k++)
if(a[k].num==num) break;
printf("%d %s %d %d %d %d %d %d\n", a[k].num, a[k].name, a[k].grade[0], a[k].grade[1],
a[k].grade[2], a[k].grade[3], a[k].grade[4], a[k].sum);
}
main()
{
struct student stu[20];
int n, number;
scanf("%d", &n);
if(n<=40&&n>=1) /*若n在正常范围内,则调用以下函数*/
{
input(stu, n);
scanf("%d",&number);
sum(stu, n);
change(stu, n);
output(stu, n, number);
}
else printf("Error!\n"); /*若n超出范围,则输出错误信息*/
}
Paste_Image.png编写一个程序,按照下列要求,创建一个含有两个成员的结构体:第一个成员是社会保障号;第二个成员是一个含三个成员的结构。它的第一个成员是名,第二个成员是名和姓中间的名字,最后一个成员是姓。创建一个含有5个此类结构的数组,输入数据,并以以下形式输出数据:Dribble,Flossie M. - 302039823名和姓中间的名字只输出了它的第一个字母,后面加了一个点。
#include<stdio.h>
#define N 20
struct stu
{
char name[N];
char xing[N];
char mid[N];
};
struct sta
{
int code;
struct stu vsta;
};
void myinput(struct sta [],int);
void myoutput(struct sta [],int);
int main()
{
struct sta vstu[5];
myinput(vstu,5);
myoutput(vstu,5);
return 0;
}
void myinput(struct sta vstu[],int n)
{
int i;
for(i=0;i<n;i++)
{
scanf("%s",vstu[i].vsta.name);
scanf("%s",vstu[i].vsta.mid);
scanf("%s",vstu[i].vsta.xing);
scanf("%d",&vstu[i].code);
}
}
void myoutput(struct sta vstu[],int n)
{
int i;
for(i=0;i<n;i++)
{
printf("%s",vstu[i].vsta.name);
printf(",");
printf("%s",vstu[i].vsta.xing);
printf(" ");
printf("%c. - ",vstu[i].vsta.mid[0]-32);
printf("%d",vstu[i].code);
printf("\n");
}
}