6-3 结构体数组按总分排序 (10 分)

6-3 结构体数组按总分排序 (10 分)

有一组学生数据,每个数据中含有三门课成绩,请按成绩总和从高到低对这组数据进行排序。 编写函数calc求出每名学生的总分。 编写函数sort按每名学生的总分从高到低对这组数据进行排序

函数接口定义:

void calc(struct student *p,int n);
void sort(struct student *p,int n);
其中 p 和 n 都是用户传入的参数。 函数calc求出p指针所指的结构体数组中 n 名学生各自的总分。 函数sort对p指针所指的结构体数组的学生数据按总分降序排序。

裁判测试程序样例:

#include <stdio.h>
struct student
{
int num;
char name[15];
float score[3];
float sum;
};
void calc(struct student *p,int n);
void sort(struct student *p,int n);
int main()
{
struct student stu[5];
int i,j;
float f;
for(i=0;i<5;i++)
{
scanf("%d%s",&stu[i].num,stu[i].name);
for(j=0;j<3;j++)
{
scanf("%f",&f);
stu[i].score[j]=f;
}
}
calc(stu,5);
sort(stu,5);
for(i=0;i<5;i++)
{
printf("%5d%15s",stu[i].num,stu[i].name);
printf(" %.1f %.1f %.1f %.1f\n",stu[i].score[0],stu[i].score[1],stu[i].score[2], stu[i].sum);
}
return 0;

/* 请在这里填写答案 */
输入样例:

1 zhang 89 87 85
2 liu 92 98 96
3 li 74 71 72
4 xion 95 98 99
5 liu 99 100 100
输出样例:

5            liu  99.0  100.0  100.0  299.0
4           xion  95.0  98.0  99.0  292.0
2            liu  92.0  98.0  96.0  286.0
1          zhang  89.0  87.0  85.0  261.0
3             li  74.0  71.0  72.0  217.0


*void calc(struct student *p,int n)
{
    int i;
    for(i=0;i<n;i++)
    {
        p[i].sum=p[i].score[0]+p[i].score[1]+p[i].score[2];
    }
}
void sort(struct student *p,int n)
{
    struct student std;
    int i,j,k;
    float max;
    for(i=0;i<n;i++)
    {
        max=0;
        for(j=i;j<n;j++)
        {
            if(max<p[j].sum)
            {
                max=p[j].sum;
                k=j;
            }
        }
        std=p[i];
        p[i]=p[k];
        p[k]=std;
    }
}*
  • 11
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值