【发布时间】:2020-03-26 17:33:40
【问题描述】:
我想生成一个随机字母,但随机性偏向于该字母的流行程度。 例如“E”,是英文字母表中最常见的字母,所以它的概率应该最高。
我发现这个frequency table 来定义一封信的受欢迎程度。
我的幼稚做法如下:
import random
popularity_dict = {'E': 21912, 'T': 16587, 'A': 14810, 'O': 14003, 'I': 13318, 'N': 12666, 'S': 11450, 'R': 10977, 'H': 10795, 'D': 7874, 'L': 7253, 'U': 5246, 'C': 4943, 'M': 4761, 'F': 4200, 'Y': 3853, 'W': 3819, 'G': 3693, 'P': 3316, 'B': 2715, 'V': 2019, 'K': 1257, 'X': 315, 'Q': 205, 'J': 188, 'Z': 128}
#scraped from the given link
letter_list = []
for letter, popularity in popularity_dict.items():
letter_list.extend([ letter] * popularity)
print(random.choice(letter_list))
我想知道是否有更有效的方法来解决这个问题
【问题讨论】:
-
如果您将其转换为概率字典(总共 1 个),那么此解决方案将起作用:stackoverflow.com/questions/40927221/…