第1关:练习-Java集合类之Map的TreeMap之单词中各字母的个数

目录

任务描述

编程要求

测试说明

参考答案


任务描述

本关任务:统计给定单词中各字母出现的字数,并按字母的升序输出结果。

编程要求

仔细阅读右侧编辑区内给出的代码框架及注释,在 Begin-End 间编写程序代码,统计给定单词中各字母出现的字数,并按字母的升序输出结果,具体要求如下:

  • 接收给定的单词(如:hello);
  • 统计单词中各字母出现的字数(key-vaue 形式,key 为字母,value 为次数);
  • 按字母的升序输出统计结果。

测试说明

平台将使用测试集运行你编写的程序代码,若全部的运行结果正确,则通关。

例: 测试输入:

  1. hello

预期输出:

  1. {e=1, h=1, l=2, o=1}

开始你的任务吧,祝你成功!

参考答案

import java.util.*;
public class CollTest {
    public static void main(String[] args) {
        // 请在Begin-End间编写代码
        /********** Begin **********/
    	   // 接收给定的单词
    Scanner input=new Scanner(System.in);
    String str=input.nextLine();
    char[] array=str.toCharArray();
    Map<Character, Integer> map=new TreeMap<>();
    	  // 统计单词中各字母的个数,key为字母,value次数,并按字母的升序输出结果
    for(int i=0;i<array.length;i++) {
    if(!map.containsKey(array[i])) {
    map.put(array[i], 1);
     }
    else{
    Integer value=map.get(array[i]);
    map.put(array[i], value+1);
    	}
    	}
    System.out.print(map);
    	
	  /********** End **********/
    }
}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值