6-1 实验11_4_综合成绩排名-Swap (100 分)

该程序实现了一个根据学生机试和加权成绩计算综合成绩的功能,并按成绩进行排序。输入包含学生人数和每个学生的学号、机试成绩、加权成绩。程序使用了结构体STUDENT存储学生信息,通过Sort函数进行排序,Swap函数用于交换两个学生信息,Comp函数用于比较学生成绩。最后输出排序后的学生信息。
摘要由CSDN通过智能技术生成
void Swap(STUDENT * s1,STUDENT * s2)
{
    STUDENT temp;
    STUDENT* temp1=&temp;
    * temp1=* s2;
    * s2=* s1;
    * s1=* temp1;
}

实验十四 共八题

众所周知,计算机院要对申请转入计算机大类的学生进行考核,考核方式包括机试和面试。学生综合成绩采取百分制,其中50%由机试成绩核算,另50%由学生已获得的加权成绩核算。综合成绩优秀者可进入面试环节。现请你写一个根据学生成绩来确定综合成绩排名的程序。

输入: 第一行为一个整数n(0<n<100),代表学生人数。 后边n行为学生信息,格式为,一个字符串代表学生学号(长度不超过15),后边为两个整数,前边的代表机试成绩,后一个代表学生已获得的加权成绩。(两类成绩均在0到100之间)。

输出: 共n行,按综合成绩(机试成绩加加权成绩)从高到低每行输出每个学生的信息,如果综合成绩相同,则机试成绩高的学生在前。每行的格式为:一个字符串(学生学号)加三个整数(4个数据之间均用一个空格分隔),这三个整数依次为综合成绩,机试成绩和加权成绩,测试用例保证输入合法且不存在成绩完全相同的学生。

程序中用的结构体定义及各成员含义如下:

typedef struct
{
    char    id[16]  ;    //学生账号 
    int    total ;    //综合成绩 
    int    ce ;    //机试成绩 
    int    ws ;    //加权成绩 
}STUDENT;

程序中用到3个函数,分别为:

void Swap(STUDENT * s1,STUDENT * s2) ;

其中参数s1,s2为指向两个结构体的指针,其功能是将这两个指针指向的结构体内的值互相交换。

int Comp(STUDENT * s1,STUDENT * s2) ;

其中参数s1,s2为指向两个结构体的指针,其功能是比较两个结构体, 如果s1>s2则返回1,否则返回0。这里s1>s2指的是s1的总分高,或者总分相同时指的是s1的机试成绩高。测试用例保证输入合法且不存在成绩完全相同的学生。

void Sort(STUDENT a[],int size) ; 

其中参数a为待排序的结构体数组,size为数组中学生的数量。其功能是将a按题目指定规则排序。

函数接口定义:

 

本题中大家只需实现下边这一个函数,另外两个函数不需实现,函数接口如下: void Swap(STUDENT * s1,STUDENT * s2) ;

裁判测试程序样例:

 

#include <stdio.h> typedef struct { char id[16] ;//学生账号 int total ; //综合成绩 int ce ; //机试成绩 int ws ; //加权成绩 }STUDENT; void Sort(STUDENT a[],int size) ; void Swap(STUDENT * s1,STUDENT * s2) ; int Comp(STUDENT * s1,STUDENT * s2) ; int main() { STUDENT stu[100] ; int i , n ; scanf("%d",&n) ; for(i=0;i<n;i++) { scanf("%s%d%d",stu[i].id,&stu[i].ce,&stu[i].ws) ; stu[i].total = stu[i].ce+stu[i].ws ; } Sort(stu,n) ; for(i=0;i<n;i++) printf("%s %d %d %d\n",stu[i].id,stu[i].total,stu[i].ce,stu[i].ws) ; return 0; } /* 请在这里填写答案 */

输入样例:

3
bupt_2018210001 78 74
bupt_2018210002 95 71
bupt_2018210003 84 75

输出样例:

bupt_2018210002 166 95 71
bupt_2018210003 159 84 75
bupt_2018210001 152 78 74
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值