JAVA处理字符串

"AABCDSTESHWEQAEFSZC45TWEYXCPIURVCSWTDBC2IOYXGTEGDTUMJHUMBJKH9FGUKNKN",请写程序找出其中有多少种字符和数字,每种字符或数字有几个并打印出来,按字符升序排列,(用Map实现)
package com.homework;

import java.util.Map;
import java.util.Set;
import java.util.TreeMap;

public class Test01 {

/**
* "AABCDSTESHWEQAEFSZC45TWEYXCPIURVCSWTDBC2IOYXGTEGDTUMJHUMBJKH9FGUKNKN",
* 请写程序找出其中有多少种字符和数字,每种字符或数字有几个并打印出来,按字符升序排列,(用Map实现)
*
* 查找每个字符在字符串出现的次数 (利用Map的键唯一,可以覆盖值) TreeMap此类保证了映射按照升序顺序排列关键字,根据使用的构造方法不同,
* 可能会按照键的类的自然顺序 进行排序(参见 Comparable), 或者按照创建时所提供的比较器进行排序。
*
* @param temp
* @return
*/
public static Map<Character, Integer> getCharCount(String temp) {
// 用Map对象来保存查找结果,key为要查询的字符,value为出现的次数
Map<Character, Integer> map = new TreeMap<Character, Integer>();
for (Character chr : temp.toCharArray()) { // 转化为字符数组
if (map.get(chr) == null) {// 值为空
map.put(chr, 1);
} else {
map.put(chr, map.get(chr) + 1);// 加1
}
}
return map;
}

// 打印
public static void prtn(Map<Character, Integer> map) {

System.out.println("字符" + "\t" + "个数");
Set<Character> s = map.keySet();

for (Character c : s) {
System.out.println(c + "\t" + map.get(c));
}
}

public static void main(String[] args) {
String str = "AABCDSTESHWEQAEFSZC45TWEYXCPIURVCSWTDBC2IOYXGTEG"
+ "DTUMJHUMBJKH9FGUKNKN";
prtn(getCharCount(str));

}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值