解题思路:
用字典解决问题,将对应的名字和分数放入字典中,每次考试后更新字典中的分数,然后用sorted排序,之后计算排名即可。
注意事项:
要注意题目中的要求,题目中说“排名是这一次考试过后的所有考试总分排名”,也就是说第n次考试之后的排名计算按照前n次考试的总分。
参考代码:
def f(n): names = [] for i in range(n): names.append(input()) dic_stu = {item:0 for item in names} #建立字典 time = int(input()) for i in range(time): for j in range(n): #每次考试后更新字典并进行排序 score,name = input().split() dic_stu[name] = dic_stu[name] + int(score) dic_stu = dict(sorted(dic_stu.items(),key = lambda x:x[1],reverse=True)) count = 0 for value in dic_stu.values(): #分数相同时DaDa的排名总在前面 count = count+1 if value == dic_stu['DaDa']: print(count) break if __name__ == '__main__': n = int(input()) f(n)
0.0分
0 人评分
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:644 |
求圆的面积 (C语言代码)浏览:1271 |
C语言程序设计教程(第三版)课后习题8.5 (C语言代码)浏览:577 |
字符逆序 (C语言代码)浏览:617 |
A+B for Input-Output Practice (VI) (C语言代码)浏览:558 |
C语言程序设计教程(第三版)课后习题10.1 (C语言代码)浏览:537 |
C语言程序设计教程(第三版)课后习题10.5 (C语言代码)浏览:956 |
1392题解(大数相加)浏览:604 |
买不到的数目 (C语言代码)浏览:3094 |
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:573 |