1. 算法描述
- 小蓝正在学习一门神奇的语言,这门语言中的单词都是由小写英文字母组成,有些单词很长,远远超过正常英文单词的长度。小蓝学了很长时间也记不住一些单词,他准备不再完全记忆这些单词,而是根据单词中哪个字母出现得最多来分辨单词。
- 现在,请你帮助小蓝,给了一个单词后,帮助他找到出现最多的字母和这个字母出现的次数。
2. 算法分析
本题简单来说就是输入一个字符串后,返回出现最多的那个字符和对应出现的次数
3. 算法思路
可以对当前字符串进行循环迭代,然后把字符串循环迭代的每一个字符当做一个k值把当存在字典里面并初始化为1,如果再次出现就让次数加1,最后在字典中找到次数最多的k值和对应的value值即可
2. 代码实现
实现代码📝:
def analyse_words(words):
word_dict = {}
for i in words:
# 如果不在字典,初始化次数为1
if i not in word_dict:
word_dict[i] = 1
# 如果在字典次数加一
else:
word_dict[i] += 1
max_key = max(word_dict, key=word_dict.get)
print('出现次数最多的是:', max_key)
print('出现次数为:', word_dict[max_key])
analyse_words('helloworld')
运行结果👇: