2020第十一届蓝桥杯JAVAB组第二场 试题 G: 单词分析

2020第十一届蓝桥杯JAVAB组第二场

试题 G: 单词分析

时间限制: 1.0s 内存限制: 512.0MB 本题总分:20 分
【问题描述】
小蓝正在学习一门神奇的语言,这门语言中的单词都是由小写英文字母组
成,有些单词很长,远远超过正常英文单词的长度。小蓝学了很长时间也记不
住一些单词,他准备不再完全记忆这些单词,而是根据单词中哪个字母出现得
最多来分辨单词。
现在,请你帮助小蓝,给了一个单词后,帮助他找到出现最多的字母和这
个字母出现的次数。
【输入格式】
输入一行包含一个单词,单词只由小写英文字母组成。
【输出格式】
输出两行,第一行包含一个英文字母,表示单词中出现得最多的字母是哪
个。如果有多个字母出现的次数相等,输出字典序最小的那个。
第二行包含一个整数,表示出现得最多的那个字母在单词中出现的次数。
【样例输入】
lanqiao
【样例输出】
a 2
【样例输入】
longlonglongistoolong
【样例输出】
o 6
【评测用例规模与约定】
对于所有的评测用例,输入的单词长度不超过 1000。

public class Demo_G单词分析 {
     

    public static void main(String[] args) {
     
        Scanner sc=new Scanner(System.in);
        //用字符串接收输入的字母
        String str=sc.next();
        //定义HashMap,key类型为Character,value类型为Integer
        Map<Character,Integer> map=new HashMap<Character, Integer>();
        //对字符串进行for循环
        for (int i = 0; i < str.length(); i++) {
     
        //获取字符串的每个字符c
            char c=str.charAt(i);
            /*判断map的key中是否包含c,如果不包含表示该字符第一次出现
            ,value赋值1并将c和1 put进map中*/
            if(!map.containsKey(c)){
     
                map.put(c,1);
            }else{
     
            /*如果map中已经存在c的key,先获取该key的value值,
            在对该value值进行自加操作,最后再put到map中*/
                int a = map.get(c);
                a++;
                map.put(c,a);
            }
        }
/*由于hashmap集合的键是Character类型时会对键值自动进行字典序排序所以
我们可以直接遍历map集合*/

        int max=0;//最大值
        char max_c=' ';//次数最多的字符
        //HashMap的遍历使用foreach循环
        for (Character key:map.keySet()) {
     
        //当遍历的value值大于max,就把该value值赋值给max,max_c就等于当前的key
            if(map.get(key)>max){
     
                max=map.get(key);
                max_c=key;
            }


        }
        //System.out.println(map);
        System.out.print(max_c);
        System.out.println(max);
    }
}

总结:这是我第一次参加蓝桥杯,看到这道题的时候的思路就是用HashMap集合处理,但是自己对这个集合的使用还不是很熟悉,不懂HashMap的key可以自动按字典序排序还有不懂HashMap的遍历,导致最后没有写出来,后来看来挺简单的。

你可能感兴趣的:(算法,hashmap,字符串)