栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

幸运数字

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

幸运数字

时间限制:1000ms

内存限制:256M

题目描述:

   青书抽奖活动,抽奖箱里有很多球,每个球上有个整数,相同数字的球可重复多次出现,每个员工抽一个,如果一个球上的数字和这个球被抽到的次数相同,那这个球称为幸运球,如果出现多个幸运球,则幸运球数字最大的为最终获奖幸运球,抽到该球的员工获得奖品。现在要找到返回最终获奖幸运球数字,如果没有返回 -1。

例如:抽到的球数字是 1 1 2 2 3 4 4 4 4 5 6

则幸运球为 4 号球

输入描述:

幸运数字数组

输出描述:

幸运数字

示例:

输入
1,1,2,2,3,4,4,4,4,5,6

输出
4

题目分析:

   该编程目标是 获取数字出现的最大重复次数,故可使用 Map 结构的 key 存放 数字, value 存放 次数。

代码实现:
package 幸运数字;

import java.util.*;


public class Main {
    public static void main(String[] args) {
        // 如果有其他情况需要判断 可修改示例代码
        Scanner cin = new Scanner(System.in);
        String str1 = cin.next();
        String[] split1 = str1.split(",");
        int[] arr = new int[split1.length];
        for (int i = 0; i < split1.length; i++) {//将字符串数组转换为数字数组
            arr[i] = Integer.parseInt(split1[i]);
        }
        int lucky = findLucky(arr);
        System.out.println(lucky);
    }
    // 请补齐方法
    public static int findLucky(int[] arr) {
        Map map = new HashMap<>();//存放对应数字的重复次数
        if(arr == null||arr.length<=0){
            return -1;
        }
        for(int i = 0 ; i < arr.length;i++){
            if(map.containsKey(arr[i])){//如果重复,value值加一
                map.put(arr[i],map.get(arr[i])+1);
            }else{//不重复,就直接添加
                map.put(arr[i],1);
            }
        }
        List> list = new ArrayList(map.entrySet());//将map转换成list,好寻找最大值
        Collections.sort(list,(o1, o2)->(o2.getValue()-o1.getValue()));//利用Collections工具类进行排序
        //获取最大value值对应的key
        return list.get(0).getKey();
    }
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/281251.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号