题目描述
输入一个只包含小写英文字母和数字的字符串,按照不同字符统计个数由多到少输出统计结果,如果统计的个数相同,则按照ASCII码由小到大排序输出。
输出描述:
一个字符串,为不同字母出现次数的降序表示。若出现次数相同,则按ASCII码的升序输出。
思路
01).创建字典,把字符串中字符个数存入字典;
02).对字典中Key即字符排序,从小到大 ,
03).再对字典的value按从大到小排序;把列表中字符拼接为字符串
代码如下:
在这里插入代码片
while 1:
try:
ss = str(input())
temp_map = {}
for i in ss.strip():
if i in temp_map:
temp_map[i] += 1
else:
temp_map[i] = 1
key_list = sorted(temp_map.items(), key=lambda x: x[0], reverse=False)
key_list.sort(key=lambda d: d[1], reverse=True)
res = ''
for i in key_list:
res = res + i[0]
print(res)
except:
break