/**
* 思路:
* 1、将字符串分离出字符,以便于统计
* 2、创建一个TreeMap集合,键(key)存字符,值(value)存字符出现次数
* 3、转换TreeMap到Set集合,Set<Entry<Character,Integer>>ts = tm.entrySet();
* 4、利用Iterator 打印 key 和 value
*/
import java.util.Iterator;
import java.util.Map.Entry;
import java.util.Set;
import java.util.TreeMap;
public class Test {
public static <E> void print(E e)
{
System.out.print(e);
}
public static void main(String[] args) {
char[] str;
String s = "a@a-bb++a"; //要获取的字符串
str = s.toCharArray(); //将字符串转换成字符数组
TreeMap<Character, Integer> tm = new TreeMap<Character, Integer>();
int count =0;
for (char c: str) //题目字符数组中的字符存入treemap
{
if ( tm.get(c) !=null) //从treemap中读取value值,如果不是null则+1,
{
count = tm.get(c);
tm.put(c,++count );
}
else //否则 value值定义为1
{
tm.put(c, 1);
}
}
//一下是读取并打印treemap的值
Set<Entry<Character,Integer>>ts = tm.entrySet();
Iterator<Entry<Character,Integer>> it = ts.iterator();
while(it.hasNext())
{
Entry<Character,Integer> en = it.next();
print( en.getKey()+"("+en.getValue()+")"+" ");
}
}
}
outPut:+(2) -(1) @(1) a(3) b(2)