题目:
描述:给出一个名字,该名字有26个字符串组成,定义这个字符串的“漂亮度”是其所有字母“漂亮度”的总和。每个字母都有一个“漂亮度”,范围在1到26之间。没有任何两个字母拥有相同的“漂亮度”。字母忽略大小写。给出多个名字,计算每个名字最大可能的“漂亮度”。
样例输入:2 zhangsan lisi
样例输出:192 101
题目分析:
每个字母的漂亮度根据字母个数排列。字母个数最多的,漂亮度=26;字母个数第二的,漂亮度=25.如果两个字母的个数相等,将漂亮度随机分配给这两个字母。
如zhangsan,a和n皆有两个,个数最多,a和n的漂亮度为26,25,z、h、g和s的个数皆为1,漂亮度为24、23、22和21.那么zhangsan的漂亮度=26*2+25*2+24+23+22+21=192
算法分析:
根据题目的意思,可以将算法分为四步,首先第一步针对输入的名字,同一大小写;第二步统计名字中每个字母出现的次数,第三步按次数多少对字母进行排序;第四步就可以计算这个名字的漂亮度了。
程序:
第一步,将大小写字母统一转换到1-26
for(i=0;i<cnt ;i++)