黑马程序员技术交流社区
标题:
测试题2
[打印本页]
作者:
郁金香大公爵
时间:
2015-7-29 11:05
标题:
测试题2
取出一个字符串中字母出现的次数。如:字符串:"abcdekka27qoq" ,输出格式为:a(2)b(1)k(2)...
* @author
*
*/
public class Test1 {
public static void main(String[] args){
String str = "abcdekka27qoq";
String char_count = getCharCount(str);
System.out.println(char_count);
}
public static String getCharCount(String str) {
char[] chs = str.toCharArray(); //将字符串转成字符数组
Map<Character,Integer> map = new TreeMap<Character,Integer>(); //定义map集合
for (int i = 0; i < chs.length; i++) { //遍历字符数组,获取每一个字母
Integer value = map.get(chs
); //将遍历到的字母作为键去查表,获取值
int count = 0; //用于记录次数
if(value != null){ //判断次数是否存在
count = value; //存在,就用count记录次数
}
count++; //次数不存在,就不记录,只对count自增变成1
map.put(chs
, count); //将字符和次数进行存储
}
return toString(map);
}
public static String toString(Map<Character, Integer> map) {
StringBuilder sb = new StringBuilder(); //使用缓冲区
Set<Character> keySet = map.keySet(); //将map集合转变成set集合
for (Iterator<Character> it = keySet.iterator(); it.hasNext();) { //通过迭代器,取出map集合中的元素
Character key = it.next();
Integer value = map.get(key);
sb.append(key+"("+value+")");
}
return sb.toString();
}
}
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2