OD C卷【智能成绩表】

题目

小明来到某学校当老师,需要将学生按考试总分或单科分数进行排名。
输入描述:

第一行输入学生人数n、科目数量m;

0<n<100; 0<m<10

第二行输入m个科目名称,以空格分开;科目只由英文字母构成,长度不超过10个字符,无重复的科目名称,且与后续输入的学生成绩一一对应;

第三行开始的n行,每行包含一个学生的姓名和该生m个科目的成绩,学生名只由英文字符构成,长度不超过10,且无重复;成绩在【0,100】的整数;

最后一行,输入排序的(单个)科目名称,若无科目名称,则按照总分排序;
输出描述:

按成绩排序的学生名字,空格分隔,成绩相同按名字字典序输出

示例1

输入:

3 2

yuwen shuxue

fangfang 95 90

xiaohua 88 95

minmin 100 82

shuxue

输出:

xiaohua fangfang minmin

说明:

按shuxue成绩排名,依次是xiaohua、fangfang、minmin

解题代码

python 复制代码
 
class Project:
    def __init__(self, id, scores):
        self.name = name 
        self.scores = scores
        self.idx = -1
        self.total_score = sum(scores)
 
def comp(a,b):
    if(a.idx != -1):
        if(a.scores[idx] != b.scores[idx]):
            if(a.scores[idx] > b.scores[idx]):
                return -1
            else:
                return 1
        else:
            if (a.name > b.name):
                return 1
            else:
                return -1
    else:
        if(a.total_score != b.total_score):
            if(a.total_score > b.total_score):
                return -1
            else:
                return 1
        else:
            if (a.name > b.name):
                return 1
            else:
                return -1
 
    
 
 
params1 = [int(x) for x in input().split(" ")]
n = params1[0]
m = params1[0]
all_project = []
all_study = input().split(" ")
 
for i in range(n):
    params = input().split(" ")
    name = params[0]
    j=1
    scores = []
    while(True):
        if(j>=m):
            break
        else:
            temp_score = int(params[j])
            scores.append(temp_score)
        j+=1
    
    all_project.append(Project(name, scores))
 
target_str = input()
idx = -1
for i in range(len(all_study)):
    if(target_str == all_study[i]):
        idx = i
        break
 
for i in all_project:
    i.idx = idx
#按照分数
all_project = sorted(all_project, key=functools.cmp_to_key(comp))
 
output_str = " "
for i in all_project:
    output_str += i.name + " "
print(output_str)
相关推荐
菠菠萝宝8 小时前
【Java八股文】10-数据结构与算法面试篇
java·开发语言·面试·红黑树·跳表·排序·lru
无双@4 天前
算法分析—— 《归并排序》
数据结构·算法·leetcode·蓝桥杯·排序算法·排序·归并
闻缺陷则喜何志丹9 天前
【C++前缀和 排序】891. 子序列宽度之和|2182
c++·算法·前缀和·力扣·排序·子序列·宽度
源代码•宸12 天前
Leetcode—252. 会议室【简单】Plus
c++·经验分享·算法·leetcode·排序
轩情吖19 天前
二叉树-堆(补充)
c语言·数据结构·c++·后端·二叉树··排序
L_M_TY22 天前
E. Correct Placement
算法·贪心·排序·双指针
m0_675988231 个月前
Leetcode40: 组合总和 II
算法·leetcode·回溯·排序·python3
A懿轩A1 个月前
C/C++ 数据结构与算法【排序】 常见7大排序详细解析【日常学习,考研必备】带图+详细代码
c语言·c++·学习·排序算法·排序
金创想1 个月前
排序的本质、数据类型及算法选择
排序
BabyFish132 个月前
hive中的四种排序类型
数据仓库·hive·hadoop·排序·order by·sorted