练习题:输入某个字符串,获取该字符串中每个字符出现的次数。
思路:字符和次数之间存在映射关系。使用TreeMap集合。
由于操作字符的关系,先将字符串转化为字符数组。对字符数组进行遍历,用每一个键作为key去map中查询。如果该字母键不存在,就将该字母作为键,值为1存储到map集合中。如果该字母键存在,就将该字母对应的值加1,并将加1后的值存储到map中,这样就会覆盖原来的值,从而记录字母出现的次数。
代码如下:
public class MapTest {
public static void main(String[] args) {
String str = "udhuchfuefv";
String s = getStringCount(str);
System.out.println(s);
}
public static String getStringCount(String str) {
//将字符串转化为字符数组
char[] ss = str.toCharArray();
//定义map集合
Map<Character,Integer> map = new TreeMap<Character,Integer>();
//遍历字符数组
for (int i = 0; i < ss.length; i++) {
Integer value = map.get(ss[i]);
//使用字符数组中的 元素作为key,去查询对应的value
if(value == null)
{map.put(ss[i], 1); //如果该字符对应的value为0,置1}
else
{map.put(ss[i], value+1); //如果value值不为空,自加1}
}
return mapToString(map);
}
public static String mapToString(Map<Character, Integer> map) {
StringBuilder sbu = new StringBuilder();
Set<Character> key = map.keySet();
Iterator it = key.iterator();
while(it.hasNext())
{
Character k = (Character)it.next();
Integer value = map.get(k);
sbu.append(k+"("+value+")");
}
return sbu.toString();
}
}