一道java编程题

随便输入一段字符串,把出现次数最多的打印出来,如:aabbbbbbbbbcccdffff,就把b打印出来,用java代码实现

package Demo;

import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;

public class Demo9 {
/**
* 随便输入一段字符串,把出现次数最多的打印出来,如:aabbbbbbbbbcccdffff,就把b打印出来,用java代码实现
*/
public static void main(String[] args) {
// 获得输入的字符串
Scanner input = new Scanner(System.in);
String str = input.next();
// 转成字符数组处理
char[] cArray = str.toCharArray();
Map<Character, Integer> map = new HashMap<Character, Integer>();
// 统计各字符出现次数
for (char c : cArray) {
Integer count = map.get(c);
if (null == count) {//第一次在map中是不可能找到该字符串的,我们直接给Integer加1
map.put(c, 1);
} else {
map.put(c, count + 1);//之后的都先取出出现的次数,在他的Integer基础上加1
}
}
int maxCount = 0;
char mostChar = '0';
// 比较获得出现次数最多的字符
for (Map.Entry<Character, Integer> entry : map.entrySet()) {//map类型的迭代
if (entry.getValue() > maxCount) {
maxCount = entry.getValue();
mostChar = entry.getKey();
}
}
// 打印出结果
System.out.println(mostChar);
}
}
温馨提示:内容为网友见解,仅供参考
第1个回答  2011-11-12
你好,按照你的要求我的代码如下,并且给足了注释,可以直接运行

import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;

public class test {
public static void main(String[] args) {
// 获得输入的字符串
Scanner s = new Scanner(System.in);
String str = s.next();
s.close();
// 转成字符数组处理
char[] cArray = str.toCharArray();
Map<Character, Integer> map = new HashMap<Character, Integer>();
// 统计各字符出现次数
for (char c : cArray) {
Integer count = map.get(c);
if (null == count) {
map.put(c, 1);
} else {
map.put(c, count + 1);
}
}
int maxCount = 0;
char mostChar = '0';
// 比较获得出现次数最多的字符
for (Map.Entry<Character, Integer> entry : map.entrySet()) {
if (entry.getValue() > maxCount) {
maxCount = entry.getValue();
mostChar = entry.getKey();
}
}
// 打印出结果
System.out.println(mostChar);
}
}

输入:aabbbbbbbbbcccdffff(打个回车)
结果:b
第2个回答  2011-11-12
String s = "aabbbbbbbbbcccdffff";
Matcher m = Pattern.compile("((.)\\2*)").matcher(s);
String l = "";
while (m.find()) {
l = l.length() < m.group(1).length() ? m.group(1) : l;
}
System.out.println(l.charAt(0));
第3个回答  2011-11-12
public class Test {
public static void main(String[] args){
System.out.print(getMaxTimes("aabbbbbbbbbcccdffff")+"");
}
public static char getMaxTimes(String src){
char[] help = new char[26];
for(int i=0;i<src.length();i++)
help[src.charAt(i)-'a']++;
int maxtimes=0;
char res = 0;
for(int i=0;i<26;i++)
if(help[i]>maxtimes) {
maxtimes=help[i];
res=(char)('a'+i);
}
return res;
}
}
相似回答