题目描述
给出一个名字,该名字有26个字符串组成,定义这个字符串的“漂亮度”是其所有字母“漂亮度”的总和。
每个字母都有一个“漂亮度”,范围在1到26之间。没有任何两个字母拥有相同的“漂亮度”。字母忽略大小写。
给出多个名字,计算每个名字最大可能的“漂亮度”。
输入描述:
整数N,后续N个名字
输出描述:
每个名称可能的最大漂亮程度
输入
2 zhangsan lisi
输出
192
101
//其实就是利用了asc码给每个字母一个不会重复的漂亮度,然后排序,把最大的度赋给出现次数最高的字母
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
while(sc.hasNext()){
int num = sc.nextInt();
String[] a = new String[num];
for(int i =0;i<num;i++){
a[i] = sc.next();
}
for(int i = 0;i<num;i++){
int[] count = new int[26];
int result = 0;
for(int j=0;j<a[i].length();j++){
if(a[i].charAt(j)>='a' && a[i].charAt(j)<='z'){
count[a[i].charAt(j)-97]++;
}
if(a[i].charAt(j)>='A' && a[i].charAt(j)<='Z'){
count[a[i].charAt(j)-65]++;
}
}
Arrays.sort(count);
for(int t=0;t<26;t++){
result +=count[t]*(t+1);
}
System.out.println(result);
}
}
}
}