学生成绩排序

7-1 结构体数组输入输出 (30 分)

使用结构数组存储学生信息,信息包括了姓名name和成绩score,按学生成绩从高到低排序,并输出。
输入格式:

编写一个函数print,输出一个学生的数据记录,一共有n个学生的数据记录,每个记录包括num、name、score[3],用主函数输入这些记录,用print函数输出这些记录。
输出格式:

输入文件首先包含一个整数n,表示有n个学生,然后是n行学生记录,一行代表一个学生。
输入样例:

对于每个学生输出他的相关记录,每个信息之间后面带两个空格,一个学生信息输出一行,如下。

4
101 Li 90 79 89
102 Ma 97 90 68
103 Wang 77 70 78
104 Sun 67 89 56
结尾无空行

输出样例:

在这里给出相应的输出。例如:

No.:101  name:Li  score:90  79  89  
No.:102  name:Ma  score:97  90  68  
No.:103  name:Wang  score:77  70  78  
No.:104  name:Sun  score:67  89  56 

 

#include<stdio.h>
struct student{//定义一个结构体分别放入学号姓名,三个成员的分数
    int num;
    char name[10];
    int s[3];
   double ave;
};
int main()
{  struct student a[1000];//建议将空空间定义的大一些,以免造成空间储存不足
  int n,i,j;
 int sum=0;
 scanf("%d",&n);
 for(i=0;i<n;i++)
 {
  scanf("%d %s %d %d %d",&a[i].num,&a[i].name,&a[i].s[0],&a[i].s[1],&a[i].s[2]);
     sum=a[i].s[0]+a[i].s[1]+a[i].s[2];//求和
 a[i].ave=(sum*1.0)/3;//求三个数的平均数
 }
 struct student t;//结构类型要一致
 for(i=0;i<n-1;i++)
 {
     for(j=0;j<n-i-1;j++)
     {
     if(a[j].ave<a[j+1].ave)
      {
     t=a[j+1];
     a[j+1]=a[j];
     a[j]=t;
        }
     }
 }
     for(i=0;i<n;i++){
      printf("%d,%s,%.2lf\n",a[i].num,a[i].name,a[i].ave);//分别输出学号,姓名,以及平均成绩
      }
        return 0;
  }

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值