package classdemo;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;
/**
* Map集合练习 需求:“fhsadfhsafjdsaoifuuqewofasjdflsafdsa”
* 获取每个字符串出现的次数,输出形式:a(1)b(2)。。。。。
*/
public class ExceptionDemo {
public static void main(String[] args) {
String str = "fhsadfhsafjdsaoifuuqewofasjdflsafdsa";
String char_count = getCharCount(str);
System.out.println(char_count);
}
private static String getCharCount(String str) {
// 将字符串转成字符数组
char[] ch = str.toCharArray();
// 定义map集合表
Map<Character, Integer> map = new TreeMap<Character, Integer>();
// 遍历数组,获取每个字母
for (int i = 0; i < ch.length; i++) {
//只对字母进行操作
if (!(ch[i] >= 'a' && ch[i] <= 'z' || ch[i] >= 'A' && ch[i] <= 'Z'))
continue;
//将获取的字母作为key去查表,获取value。
Integer value = map.get(ch[i]);
int count = 0;//用于记录次数
//如果次数存在就存在则记录次数,如果次数不存在则不记录,自增!
if (value != null) {
count = value;
}
count++;
map.put(ch[i], count);
/**
* 第二种思路
*/
// if(value == null) {
// map.put(ch[i], 1);
// }else {
// value++;
// map.put(ch[i], value);
// }
}
return toString(map);
}
private static String toString(Map<Character, Integer> map) {
//数据多,无论什么类型,最终变成字符串,使用stringBuilder
StringBuilder sb = new StringBuilder();
//遍历map集合,使用keyset
Set<Character> set = map.keySet();
for (Iterator<Character> it = set.iterator(); it.hasNext();) {
Character key = it.next();
Integer value = map.get(key);
sb.append(key + "(" + value + ")");
}
return sb.toString();
}
}
Map集合的练习:获取每个字符串出现的次数,输出形式:a(1)b(2)。。。。。
最新推荐文章于 2021-04-08 09:31:55 发布