本文共 1654 字,大约阅读时间需要 5 分钟。
给你一个其中包含不同的英文字母和标点符号的文本,你要找到其中出现最多的字母,返回的字母必须是小写形式,
当检查最想要的字母时,不区分大小写,所以在你的搜索中 “A” == “a”。 请确保你不计算标点符号,数字和空格,只计算字母。 如果你找到 两个或两个以上的具有相同的频率的字母, 返回那个先出现在字母表中的字母。 例如 – “one”包含“o”,“n”,“e”每个字母一次,因此我们选择“e”。 输入: 用于分析的文本 (str, unicode). 输出: 最常见的字母的小写形式。 前提:: 密码只包含ASCII码符号 0 < len(text) ≤ 105import collectionsimport string#import redef checkio(text): text1=[] text=text.lower() #将大写转换为小写字母 text=filter(str.isalpha,text) #去掉text字符串中非字母的字符 text1=list(text) #将text转换为list #b=collections.Counter(text1) b=collections.Counter(text1).most_common() #返回的是一个字典,common(k)里面的k是多少就返回一个列表,最常出现的几个字符,k空就返回全部 n_text=[] n_text2=[] x=b[0][1] for i in range(0,len(b)): if b[i][1]==x: n_text.append(b[i][0]) n_text2=list(set(n_text)) #去掉list中重复的元素 n_text2.sort() #将n_text2排序,默认从小到大 return n_text2[0] #replace this for solutionif __name__ == '__main__': #These "asserts" using only for self-checking and not necessary for auto-testing assert checkio("Hello World!") == "l", "Hello test" assert checkio("How do you do?") == "o", "O is most wanted" assert checkio("One") == "e", "All letter only once." assert checkio("Oops!") == "o", "Don't forget about lower case." assert checkio("AAaooo!!!!") == "a", "Only letters." assert checkio("abe") == "a", "The First." print("Start the long test") assert checkio("a" * 9000 + "b" * 1000) == "a", "Long." print("The local tests are done.")
基本思想是将字符串转换成列表,按照字符出现次数排列,取出出现次数最多的那一个或几个字符。然后出现次数为max的字符全部append进n_text2列表。
然后在n_text2中去掉重复的字符,sort排序。输出n_text2[0]转载地址:http://cjvti.baihongyu.com/