第5题:
/*通信录排序:建立一个通信录,通信录的结构记录包括:姓名、生日、电话号码;其中生日又包括三项:年、月、日。
编写程序,定义一个嵌套的结构类型,输入n(n<10)个联系人的信息,再按他们的年龄从大到小的顺序依次输出其信息。
试编写相应程序。*/
#include<stdio.h>
struct student{
char name[10];
int birthday;
char phone[11];
};
/*通信录排序:建立一个通信录,通信录的结构记录包括:姓名、生日、电话号码;其中生日又包括三项:年、月、日。
编写程序,定义一个嵌套的结构类型,输入n(n<10)个联系人的信息,再按他们的年龄从大到小的顺序依次输出其信息。
试编写相应程序。*/
#include<stdio.h>
struct student{
char name[10];
int birthday;
char phone[11];
};
void sort (struct student students[],int n)
{int i,j;
struct student temp;
{int i,j;
struct student temp;
for(i=1;i<n;i++)
for(j=0;j<n-i;j++)
if(students[j].birthday>students[j+1].birthday){
temp=students[j];
students[j]=students[j+1];
students[j+1]=temp;}
}
for(j=0;j<n-i;j++)
if(students[j].birthday>students[j+1].birthday){
temp=students[j];
students[j]=students[j+1];
students[j+1]=temp;}
}
int main(void){
int n,i;
struct student students[10];
scanf("%d",&n);
for(i=0;i<n;i++)
scanf("%s %d %s",students[i].name,&students[i].birthday,students[i].phone);
sort(students,n);
for(i=0;i<n;i++)
printf("%s %d %s\n",students[i].name,students[i].birthday,students[i].phone);
return 0;
}
int n,i;
struct student students[10];
scanf("%d",&n);
for(i=0;i<n;i++)
scanf("%s %d %s",students[i].name,&students[i].birthday,students[i].phone);
sort(students,n);
for(i=0;i<n;i++)
printf("%s %d %s\n",students[i].name,students[i].birthday,students[i].phone);
return 0;
}
![](https://img2018.cnblogs.com/blog/1619649/201906/1619649-20190625181649301-875295006.png)
第6题:
/*输入10个学生的学号、姓名和成绩,输出学生的成绩等级和不及格人数。每个学生的记录包括学号、姓名成绩和等级,要求定义和调用函数set_grade(),
根据学生成绩设置其等级,并统计不及格人数,等级设置:85~100为A,70~84为B,60~69为C,0~59为D。编写程序。*/
#include<stdio.h>
struct student{
int num;
char name[10];
};
char set_grade(int x);
int main(void)
{int n=0,i,count=0,x;
char grade;
struct student st[50];
printf("Input n:");
scanf("%d",&n);
for(i=0;i<n;i++)
{
printf("Input num:");
scanf("%d",&st[i].num);
printf("Input name:");
scanf("%s",st[i].name);
printf("Input grade:");
scanf("%d",&x);
printf("num=%d,name=%s,x=%d",st[i].num,st[i].name,x);
grade=set_grade(x);
printf("\n%c\n",grade);}
if(grade='D')
count++;
printf("count=%d\n",count++);
return 0;
}
char set_grade(int x)
{
int A,B,C,D;
#include<stdio.h>
struct student{
int num;
char name[10];
};
char set_grade(int x);
int main(void)
{int n=0,i,count=0,x;
char grade;
struct student st[50];
printf("Input n:");
scanf("%d",&n);
for(i=0;i<n;i++)
{
printf("Input num:");
scanf("%d",&st[i].num);
printf("Input name:");
scanf("%s",st[i].name);
printf("Input grade:");
scanf("%d",&x);
printf("num=%d,name=%s,x=%d",st[i].num,st[i].name,x);
grade=set_grade(x);
printf("\n%c\n",grade);}
if(grade='D')
count++;
printf("count=%d\n",count++);
return 0;
}
char set_grade(int x)
{
int A,B,C,D;
if(x>=85&&x<=100){
x='A';
return x;}
if(x>=70&&x<=84){
x='B';
return x;}
if(x>=60&&x<=69){
x='C';
return x;}
if(x>=0&&x<=59){
x='D';
return x;}
}
x='A';
return x;}
if(x>=70&&x<=84){
x='B';
return x;}
if(x>=60&&x<=69){
x='C';
return x;}
if(x>=0&&x<=59){
x='D';
return x;}
}
![](https://img2018.cnblogs.com/blog/1619649/201906/1619649-20190625183126119-449336058.png)