华为OD------智能成绩表

题目描述
小明来到某学校当老师,需要将学生按考试总分或单科分数进行排名,你能帮帮他吗?

输入描述
第 1 行输入两个整数,学生人数 n 和科目数量 m。

0 < n < 100
0 < m < 10
第 2 行输入 m 个科目名称,彼此之间用空格隔开。

科目名称只由英文字母构成,单个长度不超过10个字符。
科目的出现顺序和后续输入的学生成绩一一对应。
不会出现重复的科目名称。
第 3 行开始的 n 行,每行包含一个学生的姓名和该生 m 个科目的成绩(空格隔开)

学生不会重名。
学生姓名只由英文字母构成,长度不超过10个字符。
成绩是0~100的整数,依次对应第2行种输入的科目。
第n+2行,输入用作排名的科目名称。若科目不存在,则按总分进行排序。

输出描述
输出一行,按成绩排序后的学生名字,空格隔开。成绩相同的按照学生姓名字典顺序排序。

用例1
输入
3 2
yuwen shuxue
fangfang 95 90
xiaohua 88 95
minmin 100 82
shuxue
输出
xiaohua fangfang minmin
说明
按shuxue成绩排名,依次是xiaohua、fangfang、minmin

def my_resort(sub_name, subject, stu_info,m):
    if sub_name not in subject:
        stu_info=sorted(stu_info,key=lambda x:(-sum(int(x[i]) for i in range(1,m+1)),x[0]))
        #成绩相同则按名字字典排序,为了保证降序,故前面加-号
        stu_name=' '.join([student[0] for student in stu_info])
        print(stu_name)
    else:
        sub_index = subject.index(sub_name)
        stu_info=sorted(stu_info,key=lambda x: (-int(x[sub_index + 1]),x[0]))
        stu_name = ' '.join([student[0] for student in stu_info])
        print(stu_name)
n,m=map(int,input().split())
subject=input().split()
stu_info=[]
for i in range(n):
    temp=input().split()
    stu_info.append(temp)
sub_name=input()
my_resort(sub_name,subject,stu_info,m)
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值