python字典如何根据value值取对应的key值

在vmware面试题中要求当场写一个统计出现频率最高的10个词的算法。根据要求当场写了一个打开文件,读取每一行并分解,然后建立一个字典,如果词没出现就放入字典中,并设置value为1,如果出现过,就将对应value值增加1;然后将value值列表进行排序,最后就用到了根据value值,取对应的key值。当时上面都完成了,这里没办法,只好采用笨办法遍历的方式得到对应的key值,也就是出现频率最高的10个词。 面试官说可以根据value找到key值。

今天总算可以百度一下,解了自己心头的疑惑。

adict = {"liang":100, "liu": 20, "zhang":20, "wang": 40}

print(list(adict.values()).index(100))
print(list(adict.values()).index(20))
print(list(adict.values()).index(40))

print(list(adict.keys())[list(adict.values()).index(20)])
print(list(adict.keys())[list(adict.values()).index(100)])
print(list(adict.keys())[list(adict.values()).index(40)])

输出如下:

0
1
3
liu
liang
wang

例子参考了下面的文章,并做了扩展。
python字典如何根据value值取对应的key值

从上面的练习可以看出,如果有多个key,其value值一样,只能找到第一个value值所对应的key。所以这个在解决面试问题时,如果排名前10频率高的词有相同的出现频率时,采用这种办法不能完全达到目的,还是笨办法靠谱。

事情总是有2面性的,我们需要根据实际情况情况选择合适的解决方案。

你可能感兴趣的:(python,面试)