我这个方法还是有些繁琐的,因为对字典的使用还没有熟练掌握,大家有什么建议可以欢迎提出喔!
import math
n, m = map(int, input().split())
l = []
for i in range(n):
t = list(map(int, input().split()))
l.append(t)
d = {}
for i in range(n):
t = {l[i][0]: l[i][1]}
d.update(t)
# 以上部分可以化简,不需要先变列表再转成字典
s = math.floor(m * 1.5)
a = sorted(d.items(), key=lambda x: x[1], reverse = True)
line = a[s - 1][1]# 得到分数线
fin = {}
for i in range(n):
if a[i][1] >= line:
g = {a[i][0]:a[i][1]}
fin.update(g)
fin_s=sorted(fin.items(),key=lambda item:(-item[1],item[0]))# 需要按照题意进行排序
print(line, len(fin))
for i in range(len(fin_s)):
print(fin_s[i][0], fin_s[i][1])
a = sorted(d.items(), key=lambda x: x[1], reverse = True)
sorted是Python中对列表排序的内置函数,使用lambda来获取排序的key。
其中的d.items() 是排序的对象是d中的对象
key = lambda 表示将key遮住,使用values作为排序的对象
x : x[1] 表示的是依据第1列的内容作为排序依据
reverse = True 表示其为倒序