题目描述
贝博士最近收到了一些来自外星的信号,它们看起来是一些字符。经过贝博士的转码,把这些字符用26个小写拉丁字母表示。 贝博士叫来了助手艾小姐,请她把这些字母中出现次数最多者挑出来,并按字母表顺序排列出来(忽略空格)。
输入描述
一个小写拉丁字母构成的字符串
输出描述
按字母表顺序把出现次数最多的字母输出(忽略空格)
示例
输入:across the great wall we can reach every corner of a world
输出:er
提示:上述句中e和r出现次数最多,为7次,故输出er
输出其他字母,或输出re都是错误的(因为统计错误或未按字母表顺序)
解题思路
- 使用input函数接收字符,去掉空格;
- 利用空字典,接收循环字符串中各字母出现的顺序;
- 将字典的键按照小写字母顺序进行排序;
- 创建临时变量存储字典值中的最大值,临时列表进行接收;
- 使用join(),输出字母。
参考代码
# 接收输入字符串,并去除空格
string = input().replace(' ','')
counts = {}
# 利用字典存储各字符出现次数
for word in string:
if word.isalpha and word != '':
if word in counts:
counts[word] += 1
else:
counts[word] = 1
# 提取最大值
counts_max = max(counts.values())
# 对字典的键进行排序
counts = dict(sorted(counts.items(),key = lambda x:x[0]))
# 提取键加入到列表,也可以使用字符串相加的方式
max_list = []
for k,v in counts.items():
if v == counts_max:
max_list.append(k)
print(''.join(max_list))
欢迎交流指正,沟通代码效率提高!