优异生查询(类和对象)

题目: 编程实现查找优异生的功能——用户输入多个学生的成绩,输出总分最高的学生姓名和各科成绩
要求: 设计一个学生类(Student),包括

1)属性:姓名(name),数学成绩(mscore),语文成绩(cscore),英语成绩(escore);

2)方法:

构造方法,来构造每个具体的学生对象
计算总成绩方法getSum(self),返回三个成绩的和
获得优异生姓名,数学成绩,语文成绩,英语成绩的方法getBest(self),返回4个结果内容(优异生姓名,数学成绩,语文成绩,英语成绩)
输入格式:
通过4行输入:

第一行输入多个学生姓名,以空格分隔

第二行输入多个数学成绩,以空格分隔

第三行输入多个语文成绩,以空格分隔

第四行输入多个英语成绩,以空格分隔

注意:学生姓名个数要和成绩个数保持一致

输出格式:
在一行中,输出总分最高的学生及其各科科目成绩,以空格分隔。

输入样例:
在这里给出一组输入。例如:

Jack Tom Jim
95 84 32
90 75 45
85 90 67
结尾无空行
输出样例:
在这里给出相应的输出。例如:

Jack 95 90 85
结尾无空行

class Student:
    dicScore = dict()
    def __init__(self, name, mscore, cscore, escore):
        self.name = name
        self.mscore = mscore
        self.cscore = cscore
        self.escore = escore
        Student.dicScore[self.name] = [self.mscore, self.cscore, self.escore, self.getSum()]

    def getSum(self):
        return self.mscore + self.cscore + self.escore

    @classmethod
    def getBest(self):
        value = sorted(self.dicScore.items(), key =lambda item: item[1][-1], reverse = True)[0]
        return value[0], value[1][0], value[1][1], value[1][2]
    
names = input(">>>").split()
mscores = list(map(int, input(">>>").split()))
cscores = list(map(int, input(">>>").split()))
escores = list(map(int, input(">>>").split()))

for idx, name in enumerate(names):
    s = Student(name, mscores[idx], cscores[idx], escores[idx])
    
res = s.getBest()
print(' '.join(map(str, res)), end = '')

'''--result
>>>Jack Tom Jim
>>>95 84 32
>>>90 75 45
>>>85 90 67
Jack 95 90 85
'''


#include <stdio.h>

struct student
{
int no; //学号
char name[10];
float math,english,chinese; //三门课程的成绩
double total; //总成绩
double avr; //平均成绩

};

struct student stu[50]; //声明一个结构数组变量

struct student input();

void display(struct student stud[],int count);

void sort(struct student stud[],int count);

void main()
{
int count, i;
char ch;
 
printf("请输入学生信息(以空格分隔):");
printf("\n");

count=0;

while (1)
{
    scanf("%s", stu[count].name);
    stu[count].no = count + 1;
    count++;
    ch = getchar();
    if (ch == '\n')
    {
        break;
    }
    
}

for (i = 0; i < count; i++)
{
    scanf("%f", &stu[i].math);
}

for (i = 0; i < count; i++)
{
    scanf("%f", &stu[i].english);
}

for (i = 0; i < count; i++)
{
    scanf("%f", &stu[i].chinese);
}

printf("\n最高分为:");
sort(stu,count); //调用排序函
display(stu,1); //调用显示信息函数

}

struct student input() //录入信息函数
{
struct student studn;
scanf("%d%s%f%f%f",&studn.no,studn.name,&studn.math,&studn.english,&studn.chinese);
studn.total=studn.math+studn.english+studn.chinese;
studn.avr=studn.total/3.0;
 
return studn;
}

void display(struct student stud[],int count) //显示信息函数
{
int i;
printf("\n学号\t姓名\t数学\t英语\t语文\t总分\t平均分");
printf("\n");
for(i=0;i<count;i++)
{
printf("%d",stud[i].no);

printf("\t%s",stud[i].name);

printf("\t%.1f",stud[i].math);

printf("\t%.1f",stud[i].english);

printf("\t%.1f",stud[i].chinese);

printf("\t%.2f",stud[i].total);

printf("\t%.2f",stud[i].avr);

printf("\n");
}
}

void sort(struct student stud[],int count) //排序函数
{
int i,j;

/* 冒泡排序法*/

struct student t;

for(i=0;i<count;i++)
for(j=0;j<count-i-1;j++) //比较元素
{

if(stud[j].avr<stud[j+1].avr)
{
t=stud[j];

stud[j]=stud[j+1];

stud[j+1]=t;

}
}
} 

运行结果:

img