假设这首歌i
已经播放了f
i次,但 Zipf 定律预测它会播放z
i次。然后你定义歌曲的质量为i
i q
= i f
/ i z
。你的软件应该选择q
i
值最高的歌曲。
输入的第一行包含两个整数n
和m
( 1 <= n < 50 000
, 1 <= m <= n
),专辑中歌曲的数量,以及要选择的歌曲数量。然后按照n
线路。这些行中的第i
' 行包含一个整数f
i和字符串s
i,其中0 <= f
i< 10^12
是第i
' 首歌曲被收听的次数,而s
i是歌曲的名称。每首歌曲名称最长为 30 个字符,并且仅包含字符a-z
、0-9
和下划线 ( _
)。
输出质量最高的 m 首歌曲的列表q
i,按质量降序排列。如果两首歌曲质量相同,则优先考虑专辑中最先出现的那首(大概制作人有理由将那首歌曲放在另一首之前)。
sample input
4 2
30 one
30 two
15 three
25 four
sample output
four
two
我对python很陌生,我正在尝试解决这个难题我想我得到了正确的答案,但我必须做得更快,有什么建议吗?
from __future__ import division
def main():
import sys
from operator import itemgetter
data = sys.stdin.readlines()
line1 = data[0].split(" ")
numberofselect = line1[1]
qualitydict = {};
songdict = {};
a = 0
for x in range(1, len(data)):
item = data[x].split(" ");
item1 = item[1].split("\n");
f = float(item[0])
z = float(1/x)
qualitydict[item1[0]] = (f/z)
if ((f/z) in songdict.keys()):
songdict[(f/z)].append(item1[0])
else:
songdict[(f/z)] = [item1[0]]
items = songdict.items()
items.sort(key = itemgetter(0), reverse=True)
for key, value in items:
for element in value:
if (a < int(numberofselect)):
print element
a = a + 1
main();