package en.iteast.map;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;
public class Test {
public static void main(String[] args) {
String string = "++++hajke---- shakh";
String string2 = getCharacterNumber(string);
System.out.println(string2);
}
/*
* 需求:得到字符串中字母出现的次数
*/
public static String getCharacterNumber(String string){
//1.将字符串转变为字符存入到字符数组中
char[] stringChar = string.toCharArray();
//2.定义Map集合类
Map<Character, Integer> map = new TreeMap<Character, Integer>();
//3.遍历字符数组。获取每一个字母
for (int i = 0; i < stringChar.length; i++) {
if(!(stringChar[i] >= 'a' && stringChar[i] <= 'z' || stringChar[i] >= 'A' && stringChar[i] <= 'Z'))
continue;//继续循环---假如该判断条件是为了只计数26个大小
写字母
//将遍历到的字母作为键去查表。获取值。
Integer vaInteger = map.get(stringChar[i]);
//版本一:
// if (vaInteger == null) {
// map.put(stringChar[i], 1);
// //如果键所对应的值为null,那么将该null位用1填充
// } else {
// vaInteger++;
// map.put(stringChar[i], vaInteger);
// }
//改进版本二:(与上面代码码意一样)
Integer counter = 0;
if (vaInteger != null) {
counter = vaInteger;
}
counter++;
map.put(stringChar[i], counter);
}
return toString(map);
}
//将map集合中的元素转为字符串
private static String toString(Map<Character, Integer> map) {
//1.数据多,无论类型是什么,最终都要变成字符串。所以可以用
StringBuilder sBuilder = new StringBuilder();
//2.遍历集合map,keySet
Set<Character> keySet = map.keySet();//得到map中键的集合
for (Iterator<Character> iterator = keySet.iterator(); iterator.hasNext();) {
Character key = iterator.next();
Integer values = map.get(key);
sBuilder.append(key+"("+values+")"+"\t");
}
return sBuilder.toString();
//注意:该toString()方法不可省略,因为sBuilder类型为StringBuilder,而需要返回的为String
}
}
输出结果:
a(2) e(1) h(3) j(1) k(2) s(1)