题解 | #名字的漂亮度#

名字的漂亮度

http://www.nowcoder.com/practice/02cb8d3597cf416d9f6ae1b9ddc4fde3

num = int(input())
for i in range(num):
    b = list(input())
    s = {} #统计字符出现的次数
    for i in range(len(b)):
        if(b[i] not in s):
            s[b[i]] = 1 #第一次出现加入s
        else:
            s[b[i]] += 1 #不是第一次出现则出现的次数加一
    c = []
    d = sorted(s.items(),key=lambda ele:ele[1],reverse = True) #对s按照字符出现的次数从大到小排序
    num = 0
    for i in range(len(d)):
        num += (26-i) * (int(d[i][1])) #出现的最多次数的字符赋予26,第二多的赋予25,以此类推,他们,他们出现的次数和权值由此得到最大值
    print(num)
华为机试题解(prod.by kedao) 文章被收录于专栏

华为实习机试题解

全部评论

相关推荐

不愿透露姓名的神秘牛友
昨天 18:19
个个985的硕士闭着眼睛都有15k以上的月薪,天天嚷嚷着研究生白度读了,天天嚷嚷着反向读研了........
MMMJC:不读研22本科出去的基本都拿28k呢,你不能用25的研究生和25的本科生比然后说没反向读研,而是25研和22本比呀
点赞 评论 收藏
分享
废物一个0offer:认真的吗二本本科找人工智能岗位
点赞 评论 收藏
分享
评论
1
2
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务