方法1:通过map的方法实现:
public static void main(String[] args) {
//定义随机的字符串
String temp = "udrcfpornv98our893u89qrepiqfjeiqpofj8wty431302jr32i0r4ju30";
//将其转换为char类型数组
char[] tempArray = temp.toCharArray();
Map map = new HashMap<>();
int j = 1;
for (int i = 0; i < tempArray.length; i++) {
//当map中没有对应key时,向map中put这个key并赋予0
if (map.get(tempArray[i]) == null) {
map.put(tempArray[i], j);
} else {
//当map中有这个key时,将map中的值+1
map.put(tempArray[i], (Integer) map.get(tempArray[i]) + 1);
}
}
System.out.println(map);
}
方法2:使用字符串拼接的方式实现:
public static void main(String[] args) {
//定义随机的字符串
String temp = "udrcfpornv98our893u89qrepiqfjeiqpofj8wty431302jr32i0r4ju30";
//将其转换为char类型数组
char[] tempArray = temp.toCharArray();
//将char类型数组变成String类型数组
String[] string = Arrays.toString(tempArray).replace("[", "").replace("]", "").split(",");
//将String类型的数组遍历放入set这个不可重复的集合容器中
Set set = new HashSet();
for (int i = 0; i < string.length; i++) {
set.add(string[i].trim());
}
//遍历set
Iterator<String> it = set.iterator();
while (it.hasNext()) {
String str = it.next();
//用遍历得到字符串切割temp字符串获取到数组的长度然后-1即为存在的个数
int a = temp.split(str).length - 1;
System.out.println(str + "===========" + a);
}
}