1.建立一个通信录,通信录的结构体记录包括:姓名、生日、电话号码;其中生日又包括三项:年、月、日。编写程序,定义一个嵌套的结构类型,输入n(n<10)个联系人的信息,再按他们的年龄大小的顺序依次输出其信息。
#include<stdio.h>
struct friends{
char name[10];
int phone;
int birthday;
};
struct birthday{
int year;
int month;
int day;
};
void sort(struct friends s[],int n)
{
int i,j;
struct friends temp;
for(i=1;i<n;i++)
for(j=0;j<n-i;j++)
if(s[j].birthday>s[j+1].birthday)
{
/*经典三段交换*/
temp=s[j];
s[j]=s[j+1];
s[j+1]=temp;
}
}
int main(void)
{
int i,n;
struct friends friends[10];
printf("输入人数:n");
scanf("%d",&n);
for(i=0;i<n;i++)
scanf("%s%d%d",friends[i].name,&friends[i].phone,&friends[i].birthday);
/*按年龄从大到小排序*/
sort(friends,n);
for(i=0;i<n;i++)
printf("%s%4d%4d\n",friends[i].name,friends[i].phone,friends[i].birthday);
return 0;
}
struct friends{
char name[10];
int phone;
int birthday;
};
struct birthday{
int year;
int month;
int day;
};
void sort(struct friends s[],int n)
{
int i,j;
struct friends temp;
for(i=1;i<n;i++)
for(j=0;j<n-i;j++)
if(s[j].birthday>s[j+1].birthday)
{
/*经典三段交换*/
temp=s[j];
s[j]=s[j+1];
s[j+1]=temp;
}
}
int main(void)
{
int i,n;
struct friends friends[10];
printf("输入人数:n");
scanf("%d",&n);
for(i=0;i<n;i++)
scanf("%s%d%d",friends[i].name,&friends[i].phone,&friends[i].birthday);
/*按年龄从大到小排序*/
sort(friends,n);
for(i=0;i<n;i++)
printf("%s%4d%4d\n",friends[i].name,friends[i].phone,friends[i].birthday);
return 0;
}
2.输入10个学生的学号、姓名和成绩,输出学生的成绩等级和不及格人数。每个学生的记录包括学号、姓名成绩和等级,要求定义和调用函数set_grade(),根据学生成绩设置其等级,并统计不及格人数,等级设置:85~100为A,70~84为B,60~69为C,0~59为D。
#include<stdio.h>
#define N 10
int set_grade(struct students*p);
struct students{
int num;
char name[10];
int score;
char grade;
};
int set_grade(struct students *p,int n)
{
int i,count=0;
for(i=0;i<N;i++,p++)
{
if((*p).score<60)
{(*p).grade='D';
count++;
}
else if((*p).score>=60&&(*p).score<=69)
{(*p).grade='C';
count++;
}
else if((*p).score>=70&&(*p).score<=84)
{(*p).grade='B';
count++;
}
else
(*p).grade='A';
}
return count;
}
int main()
{
struct students st[10],*str;
int i,n,count;
str=st;
scanf("%d\n",&n);
for(i=0;i<n;i++){
scanf("%d%s%d",&st[i].num,st[i].name,&st[i].score);
}
count=set_grade(str,n);
printf("The count for failed (<60): %d\n", count);
printf("The grades:\n");
for(i = 0; i < n; i++)
printf("%d %s %c\n", st[i].num, st[i].name, st[i].grade);
return 0;}
#define N 10
int set_grade(struct students*p);
struct students{
int num;
char name[10];
int score;
char grade;
};
int set_grade(struct students *p,int n)
{
int i,count=0;
for(i=0;i<N;i++,p++)
{
if((*p).score<60)
{(*p).grade='D';
count++;
}
else if((*p).score>=60&&(*p).score<=69)
{(*p).grade='C';
count++;
}
else if((*p).score>=70&&(*p).score<=84)
{(*p).grade='B';
count++;
}
else
(*p).grade='A';
}
return count;
}
int main()
{
struct students st[10],*str;
int i,n,count;
str=st;
scanf("%d\n",&n);
for(i=0;i<n;i++){
scanf("%d%s%d",&st[i].num,st[i].name,&st[i].score);
}
count=set_grade(str,n);
printf("The count for failed (<60): %d\n", count);
printf("The grades:\n");
for(i = 0; i < n; i++)
printf("%d %s %c\n", st[i].num, st[i].name, st[i].grade);
return 0;}