本文共 1354 字,大约阅读时间需要 4 分钟。
为了解决这个问题,我们需要根据司马光的德才论对考生的录取排名进行排序。德才论将考生分为四类,每类按不同的规则排序,最终合并后输出排名。
分类考生:根据德分和才分是否达到特定的分数线,将考生分为四类:
排序每类考生:每类内部按德才总分降序排列,若总分相同则按德分降序,若德分相同则按准考证号升序排列。
合并排序结果:将四类考生的排序结果合并,得到最终的录取排名。
n, l, h = map(int, input().split())students = []for _ in range(n): parts = input().split() students.append((parts[0], int(parts[1]), int(parts[2])))s1 = []s2 = []s3 = []s4 = []for student in students: qno, d, c = student if d >= h and c >= h: s1.append(student) elif d >= h and c >= l: s2.append(student) elif d >= c and d >= l: s3.append(student) else: if d >= l or c >= l: s4.append(student)def sort_students(students): return sorted(students, key=lambda x: (-(x[1] + x[2]), -x[1], x[0]), reverse=False)s1_sorted = sort_students(s1)s2_sorted = sort_students(s2)s3_sorted = sort_students(s3)s4_sorted = sort_students(s4)sorted_list = s1_sorted + s2_sorted + s3_sorted + s4_sortedprint(len(sorted_list))for student in sorted_list: print(f"{student[0]} {student[1]} {student[2]}") 这种方法确保了每个考生都按正确的规则被分类和排序,最终的结果符合题目要求。
转载地址:http://kdjaz.baihongyu.com/