问题描述:
小蓝正在学习一门神奇的语言,这门语言中的单词都是由小写字母组成,
有些单词很长,远远超过正常英文单词的长度。小蓝学了很长时间也记不住一些单词,
他准备不再完全记忆这些单词,而是根据单词中哪个字母出现的最多来分辨单词。
请你帮助小蓝,给了一些单词后,帮助他找到出现最多的字母和这个字母出现的次数。
输入格式:
输入一行包含一个单词,单词只有小写英文字母组成。
输出格式:
输出两行,第一行包含一个英文字母,表示单词中出现最多的字母是哪个。
如果有多个字母出现的次数相等,输出字典序最小的那个。
第二行包含一个整数,表示出现的最多的那个字母在单词中出现的次数。
样例输入:
lanqiao
样例输出:
a
2
样例输入:
longlonglongistoolong
样例输出:
o
6
代码:
导入相应的包
import java.io.BufferedReader;
import java.io.InputStreamReader;
public static void main(String[] args) throws Exception {
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
String line = "";
try{
line = reader.readLine();// 读取一行字符串
} catch(IOException e){
e.printStackTrace();
}
// 将字符串转化为字符数组
char[] c = line.toCharArray();
int[] a = new int[26];
for (int i = 0; i < line.length(); i++) {
// 获取某个字符的索引位置
int n = c[i] - 'a';
a[n]++;
}
// 统计出出现最多字符的次数
int max = a[0];
int res = 0; // 记录出现最多次数的索引
for (int i = 1; i < a.length; i++) {
if (max < a[i]) {
max = a[i]; // 记录出现最多的次数
res = i; // 记录是哪个字符的索引
}
}
// 统计出是哪一个字符出现最多
char result = (char) (res + 'a');
// 输出结果
System.out.println(result);
System.out.println(max);
}