java Map练习-获取字符串中字母出现次数(TreeMap实现)

/*
练习:
"kbashbdjsgfwhofihbfkwejhfiubjzfhaads"获取该字符串中的字母出现次数。

希望打印结果:a(3)b(4)d(2)...

通过结果发现,每一个字母都有对应的次数。、
说明字符和次数之间都有映射关系。

注意:当发现有映射关系是,可以选择map集合。
因为map集合中存放的就是映射关系。

为什么使用map集合呢?
当数据之间存在着映射关系时,就想到了map集合。


思路:
1,利用String类的charAt()方法遍历字符串中的每一个字符。
2,定义一个map,因为输出结果是有序的,所以使用TreeMap集合。
3,遍历字符串中的每个字符,判断map中是否存在此键,
   若存在,则键值+1;
   若不存在,则将该字符作为键存入map,并赋予键值为1.
*/

import java.util.*;
class MapTest3 
{
	public static void main(String[] args) 
	{
		String str="kbashbdjsgfwhofihbfkwejhfiubjzfhaads";
		TreeMap tm=new TreeMap();
		for(int i=0;i<str.length();i++)
		{
			char ch=str.charAt(i);
			if(!(tm.containsKey(ch)))
				tm.put(ch,1);
			else
			{
				int t=(int)(tm.get(ch))+1;
				tm.put(ch,t);
			}
		}
	
		Set s=tm.keySet();

		Iterator it=s.iterator();
		while(it.hasNext())
		{
			char chr=(char)it.next();
			int num=(int)tm.get(chr);
			sop(chr+"..."+num);
		}
	}

	public static void sop(Object obj)
	{
		System.out.println(obj);
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值