给你一段文本,其中包含不同的英文字母和标点符号。
你要找到其中那个出现 最多 的 字母,返回的字母必须是 小写形式。
注意不要管标点符号、数字和空格,只要字母!
如果你找到 两个或两个以上出现频率相同的字母, 那么返回字母表中靠前的那个。 例如“one”包含“o”、“n”、“e”每个字母一次,因此我们选择“e”。
方法一、
def wanted(text):
text=text.lower() #全部改为小写
target_letter = ''
target_count = 0
for i in range(len(text)):
count = text.count(text[i])
if not text[i].isalpha() or target_letter == text[i]:
# 避免重复判断
continue
if count == target_count:
# 比较字母表顺序
orders = [text[i], target_letter]
orders.sort()
target_letter = orders[0]
elif count > target_count:
target_count = count
target_letter = text[i]
return [target_letter, target_count]
res = wanted('iiiIIIIoJJDL,。、SPPNNs')
print(res)
方法二、
import string
class Solution:
def getMostWord(self,wordstr):
#将字符串小写化
wordstr = wordstr.lower()
#string.ascii_lowercase表示字母串'abcdef··z'
return max(string.ascii_lowercase, key=wordstr.count)
handler=Solution()
re=handler.getMostWord("HOW,。、;ldfosudfjnxchvJJJvdjjjjdlsllhh")
print(re)