结构体实验

心得:

在定义嵌套的结构类型时,必须先定义成员的结构类型,再定义主结构类型。

 

通讯录排序:

建立一个通信录,通信录的结构体记录包括:姓名、生日、电话号码;其中生日又包括三项:年、月、日。编写程序,定义一个嵌套的结构类型,输入n(n<10)个联系人的信息,再按他们的年龄大小的顺序依次输出其信息。

#include<stdio.h>
#include<string.h>
struct birthday{
       double year;
    int month,day;
};
struct phone{
 int num;
 char name[10];
 struct birthday bd;
}
;
int main()
{
 int i,j,n ,max;
 struct phone p[100],t;
 printf("Entern n:");
 scanf("%d",&n);
 printf("请输入通讯人姓名,电话号码,生日\n");
 for(i=0;i<n;i++)
  scanf("%s%d%lf%d%d",p[i].name,&p[i].num,&p[i].bd.year,&p[i].bd.month,&p[i].bd.day);
 for(i=0;i<n-1;i++){
  max=i;
  for(j=i+1;j<n;j++){
   if(p[j].bd.year<p[max].bd.year){
      t=p[max];
         p[max]=p[j];
      p[j]=t;
   }
   else if(p[j].bd.month<p[max].bd.month){
         t=p[max];
            p[max]=p[j];
          p[j]=t;
   }
    else if(p[j].bd.day<p[max].bd.day){
           t=p[max];
              p[max]=p[j];
           p[j]=t;   
   }
  }
 }
 printf("Birthday order is\n:");
   for(i=0;i<n;i++)
    printf("name %s \n telephone number %d\n  %1.1f%d%d\n",p[i].name,p[i].num,p[i].bd.year,p[i].bd.month,p[i].bd.day);
return 0;
}

 

 

 

按等级统计学生成绩:

输入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];
    int res;
    char rank;
};
int set_grade( struct student t[], int n );
int main()
{ 
 struct student t[10];
    int n, i, count;
 printf("请输入学生个数:");
    scanf("%d\n", &n);
 printf("请输入学生 学号 姓名成绩");
   for(i = 0; i < n; i++){
    scanf("%d%s%d", &t[i].num, t[i].name, &t[i].res);
 }
    count = set_grade(t, 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", t[i].num, t[i].name, t[i].rank);
return 0;
}
int set_grade( struct student t[], int n )
{
 int count = 0, i;
     for(i = 0;i<n;i++){
   if(t[i].res<60){
           t[i].rank = 'D';
           count++;
   }
         else if((t[i].res<70)&&(t[i].res>=60)){
           t[i].rank = 'C';
   }
         else if((t[i].res<85)&&(t[i].res>=70)){
           t[i].rank = 'B';
  }
         else{
           t[i].rank = 'A';
   }
}
return count;
}

posted @ 2019-06-25 18:25  易哓霞  阅读(352)  评论(0编辑  收藏  举报