给定字符串,返回每个字符出现的个数。(正常、键值)
-
- 普通方法
- 主要需要解决的问题:已记录的字符,在后面再次被记录。
- 解决方法:创建新的数组,默认都为0,当字符串中字符被记录时,数组中与该字符在字符串中对应下标变为1,代表已记录,为1的不再进行记录。
public class StringDemo3_4 {
public static void main(String[] args) {
String str = "9375f41b5!1.4&./8e;f$#hg5gf9d9519gr8hgjk6f1d44bf4";
//获取字符串长度
int length = str.length();
//新数sign,默认值为0(0代表str字符串中对应下标的数未记录)
int[] sign = new int[length];
//通过循环进行统计
for (int i = 0; i < length; i++) {
//count来记录相同字符的个数
int count = 0;
//根据指定下标返回对应的值并赋值给字符ci
char ci = str.charAt(i);
//标记,判定此时数是否已记录,未记录继续运行
if (sign[i] == 0) {
for (int j = 0; j < length; j++) {
//
char cj = str.charAt(j);
//记录与ci相同的数据
if (ci == cj) {
count++;
//记已记录的字符,对应标记变为1
sign[j] = 1;
}
}
//count不为0,证明进行了记录,输出当前字符的个数
if (count != 0) {
System.out.println(ci + ":" + count);
}
}
}
}
}
- 使用键值方法
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
public class MapDemo3_1 {
public static void main(String[] args) {
//定义字符串
String str = "fgvghvhjb0kj65415$%0#%0xwxvcxs50646518066%#&@$opkpwzxw0zw0smnxbx(ggv...6b7*&%$";
char[] cs = str.toCharArray();
//创建映射对象
Map<Character, Integer> map = new HashMap<>();
for (int i = 0; i < cs.length; i++) {
//判断是否已经存在该键
if (map.containsKey(cs[i])) {
//判断存在,值+1,覆盖之前的映射
//map.get(cs[i])根据键返回值,+1赋予新值
map.put(cs[i], map.get(cs[i]) + 1);
} else {
//不存在,添加元素,值为1
map.put(cs[i], 1);
}
}
//调用方法把映射中所有的键存放到Set集合中
Set<Character> set = map.keySet();
//遍历Set集合
for (Character s : set) {
//由键来获取值,获取的值即为统计的个数
System.out.println(s + ":" + map.get(s));
}
//System.out.println(cs.length);
}
}