题目: 编程实现查找优异生的功能——用户输入多个学生的成绩,输出总分最高的学生姓名和各科成绩
要求: 设计一个学生类(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;
}
}
}
运行结果: