描述
输入一个只包含小写英文字母和数字的字符串,按照不同字符统计个数由多到少输出统计结果,如果统计的个数相同,则按照ASCII码由小到大排序输出。
数据范围:字符串长度满足 1 \le len(str) \le 1000 \1≤len(str)≤1000
输入描述:
一个只包含小写英文字母和数字的字符串。
输出描述:
一个字符串,为不同字母出现次数的降序表示。若出现次数相同,则按ASCII码的升序输出。
示例1
输入:
aaddccdc
复制输出:
cda
复制说明:
样例里,c和d出现3次,a出现2次,但c的ASCII码比d小,所以先输出c,再输出d,最后输出a.
核心是先按照ascii排序,在按照数量大小排序:
方法一:
while True:
try:
s = input()
d = {}
st = set(s)
for i in st:
d[i] = s.count(i)
l = sorted(((k, v) for k, v in d.items()), key=lambda x: x[0])
l = sorted(l, key=lambda x: x[1],reverse=True)
for i in l:
print(i[0], end="")
except:
break
优化:
while True:
try:
a = input()
s = sorted(set(a))
ss = sorted(s,key=lambda x:a.count(x),reverse=True)
print(''.join(ss))
except:
break