3634找出数组中的幸运数

Posted 小雷FansUnion

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了3634找出数组中的幸运数相关的知识,希望对你有一定的参考价值。

在整数数组中,如果一个整数的出现频次和它的数值大小相等,我们就称这个整数为「幸运数」。

给你一个整数数组 arr,请你从中找出并返回一个幸运数。

如果数组中存在多个幸运数,只需返回 最大 的那个。
如果数组中不含幸运数,则返回 -1 。
 

示例 1:

输入:arr = [2,2,3,4]
输出:2
解释:数组中唯一的幸运数是 2 ,因为数值 2 的出现频次也是 2 。
示例 2:

输入:arr = [1,2,2,3,3,3]
输出:3
解释:1、2 以及 3 都是幸运数,只需要返回其中最大的 3 。
示例 3:

输入:arr = [2,2,2,3,3]
输出:-1
解释:数组中不存在幸运数。
示例 4:

输入:arr = [5]
输出:-1
示例 5:

输入:arr = [7,7,7,7,7,7,7]
输出:7

来源:力扣(LeetCode)
链接:力扣
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

package cn.fansunion.leecode.isNumber;

import java.util.ArrayList;

import java.util.HashMap;

import java.util.List;

import java.util.Map;

/**

 * 找出数组中的幸运数

 * 在整数数组中,如果一个整数的出现频次和它的数值大小相等,我们就称这个整数为「幸运数」。

给你一个整数数组 arr,请你从中找出并返回一个幸运数。

如果数组中存在多个幸运数,只需返回 最大 的那个。

如果数组中不含幸运数,则返回 -1 。

来源:力扣(LeetCode)

链接:力扣

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

 * @author wen.lei@brgroup.com

 *

 * 2022-2-16

 */

public class FindLuckyIntegerInAnArray

     

    /*    输入:arr = [2,2,3,4]

        输出:2

        解释:数组中唯一的幸运数是 2 ,因为数值 2 的出现频次也是 2 。

     

        输入:arr = [1,2,2,3,3,3]

        输出:3

        解释:1、2 以及 3 都是幸运数,只需要返回其中最大的 3 。

     

        输入:arr = [2,2,2,3,3]

        输出:-1

        解释:数组中不存在幸运数。

     

        输入:arr = [5]

        输出:-1

     

        输入:arr = [7,7,7,7,7,7,7]

        输出:7*/

    /**

     * 可读性第一位,方便代码复用;核心业务逻辑,单独维护

     * @param arr

     * @return

     */

    public int findLucky(int[] arr)

        if(arr==null || arr.length==0)

            return -1;

        

        //每个数字的次数map,num-count

        Map<Integer,Integer> numCountMap=numCountMap(arr);

        List<Integer> allLuckyNumList=allLuckyNumList(arr,numCountMap);

        int maxLuckyNum=maxLuckyNum(allLuckyNumList);

        return maxLuckyNum;

    

    /**

     * 从幸运数中返回最大的一个或者-1表示没有

     * @param allLuckyNumList

     * @return

     */

    private int maxLuckyNum(List<Integer> allLuckyNumList)

        int max=-1;

        for (Integer luckyNum : allLuckyNumList)

            if(luckyNum>max)

                max=luckyNum;

            

        

        return max;

    

    /**

     * 遍历数组,根据数字和出现的次数,找到所有的幸运数

     * @param arr

     * @param numCountMap

     * @return

     */

    private List<Integer> allLuckyNumList(int[] arr, Map<Integer, Integer> numCountMap)

        List<Integer> allLuckyNumList = new ArrayList<>();

        for (int num : arr)

            //此处不可能Null

            int count=numCountMap.get(num);

            if(num== count)

                allLuckyNumList.add(num);

            

        

        return allLuckyNumList;

    

    /**

     * 遍历数组,每个数字和对应的次数map

     * @param arr

     * @return

     */

    private Map<Integer, Integer> numCountMap(int[] arr)

        Map<Integer, Integer> numCountMap = new HashMap<>();

        for (int num : arr)

            Integer count=numCountMap.get(num);

            if(count==null)

                count=1;

            else

                count++;

            

            numCountMap.put(num, count);

        

        return numCountMap;

    

     

    //网友解法,代码极简;用数组代替map,取最大值,从后向前

    public int findLucky2(int[] arr)

        int[] map = new int[501];

        for(int num : arr) map[num]++;

        for(int i=500; i>0; i--)

            if(i==map[i])

                return i;

        return -1;

    

package test.leecode.array;

import org.junit.Assert;

import org.junit.Test;

import cn.fansunion.leecode.isNumber.FindLuckyIntegerInAnArray;

/**

 * @author wen.lei@brgroup.com

 *

 *         2022-2-16

 */

public class FindLuckyIntegerInAnArrayTest

    @Test

    public void test()

        FindLuckyIntegerInAnArray array = new FindLuckyIntegerInAnArray();

        int[] lucky2 = new int[] 2234;

        Assert.assertEquals(2, array.findLucky(lucky2));

        int[] lucky3 = new int[] 122333;

        Assert.assertEquals(3, array.findLucky(lucky3));

        int[] luckyNo = new int[] 22233;

        Assert.assertEquals(-1, array.findLucky(luckyNo));

        int[] luckyNo1 = new int[] 5;

        Assert.assertEquals(-1, array.findLucky(luckyNo1));

        int[] lucky7 = new int[] 7777777;

        Assert.assertEquals(7, array.findLucky(lucky7));

    

以上是关于3634找出数组中的幸运数的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode1394-找出数组中的幸运数

315找出数组中的幸运数

LeetCode 540. 有序数组中的单一元素(二分+异或技巧) / 1380. 矩阵中的幸运数 / 1719. 重构一棵树的方案数

c语言:如果有一大堆数,怎么找出其中出现次数最多的那个

LeetCode 1380 矩阵中的幸运数[数组] HERODING的LeetCode之路

「 每日一练,快乐水题 」540. 有序数组中的单一元素