• 781. 森林中的兔子



    🐇781. 森林中的兔子

    森林中有未知数量的兔子。提问其中若干只兔子 “还有多少只兔子与你(指被提问的兔子)颜色相同?” ,将答案收集到一个整数数组 answers 中,其中 answers[i] 是第 i 只兔子的回答。

    给你数组 answers ,返回森林中兔子的最少数量。

    来源:力扣(LeetCode)

    链接:https://leetcode.cn/problems/rabbits-in-forest

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

    🐰解题思路

    🐹给兔子分组

    在这里插入图片描述

    先排序,让相同的兔子在一起

    这样就可以让相同的兔子分组,组内自我消化

    在这里插入图片描述

    排序好了,我们要怎么计算出相同的兔子的数量呢,
    我们发现第一种颜色有 4 只兔子的回答为 1
    那么在第一种颜色中可以分为 2 只兔子为一组
    因为 1 代表这除了自己还有另外一只兔子颜色相同
    因此 2 只兔子为一组,因此第一种颜色的兔子有 4 只

    到了第 2 种颜色
    2 代表着除了自己还有 2 只兔子颜色相同
    因此需要分成 3 只兔子为一组
    但第二种颜色的兔子在数组中只有 2 只,无法凑齐 3 只
    证明还有兔子没被调查,需要在额外补一只兔子,
    因此第二种颜色的兔子数量为 3

    在这里插入图片描述

    同理可得,第三种颜色的兔子有 8 只
    第四种颜色的兔子有 5 只,因为数组中只有 3 只,需要另外补 2 只,
    第五种颜色的兔子有 6 只

    🐼计算公式

    变量 x 代表有多少只兔子颜色相同
    c 代表当前颜色的兔子在数组中有多少只
    如果当前数是 x,有 c 只,有几组?

    在这里插入图片描述

    我们以 7 个 3 为例子
    3 代表除了自己有 3 只兔子颜色相同
    因此 4 只兔子为一组
    我们需要分出 2 组
    因此为 7/4 向上取整
    那么怎么向上取整
    原本是 a/b
    向上取整变为
    (a+(b-1))/b

    在这里插入图片描述

    因此最后公式为((c+x)/(x+1))*(x+1),

    🦘代码

    class Solution {
        public int numRabbits(int[] answers) {
            int n=answers.length;
            if(answers==null||n==0){
                return 0;
            }
            Arrays.sort(answers);
            int x=answers[0];
            int c=1;
            int ans=0;
            for(int i=1;i<n;i++){
                if(x!=answers[i]){
                    ans+=((c+x)/(x+1))*(x+1);
                    x=answers[i];
                    c=1;
                }else{
                    c++;
                }
            }
            return ans+((c+x)/(x+1))*(x+1);
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
  • 相关阅读:
    组件通信的方法
    Java.lang.Character类中isLowerCase()方法具有什么功能呢?
    C++的流和文件介绍
    Vue基础理论篇
    CSRF和XSS是什么?
    Java8新特性
    C语言中的 |、||、&、&&、^、~、<<、>> 运算符
    C#学习 - 方法的定义、调用、调试
    Quest 3期间Sui上游戏处理了数百万笔交易
    【牛客SQL必知必会 3天热身】01. 基本的检索、排序、过滤
  • 原文地址:https://blog.csdn.net/xiaolu567/article/details/126257659