781. 森林中的兔子

简介: 781. 森林中的兔子

题目

image.png

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

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

来源:力扣(LeetCode)

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

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

思路

两只相同颜色的兔子看到的其他同色兔子数必然是相同的。反之,若两只兔子看到的其他同色兔子数不同,那么这两只兔子颜色也不同。

因此,将 \textit{answers}answers 中值相同的元素分为一组,对于每一组,计算出兔子的最少数量,然后将所有组的计算结果累加,就是最终的答案。

例如,现在有 1313 只兔子回答 55。假设其中有一只红色的兔子,那么森林中必然有 66 只红兔子。再假设其中还有一只蓝色的兔子,同样的道理森林中必然有 66 只蓝兔子。为了最小化可能的兔子数量,我们假设这 1212 只兔子都在这 1313 只兔子中。那么还有一只额外的兔子回答 55,这只兔子只能是其他的颜色,这一颜色的兔子也有 66 只。因此这种情况下最少会有 1818 只兔子。

一般地,如果有 xx 只兔子都回答 yy,则至少有 \lceil\dfrac{x}{y+1}\rceil⌈
y+1
x

⌉ 种不同的颜色,且每种颜色有 y+1y+1 只兔子,因此兔子数至少为

\lceil\dfrac{x}{y+1}\rceil\cdot(y+1)

y+1
x

⌉⋅(y+1)

我们可以用哈希表统计 \textit{answers}answers 中各个元素的出现次数,对每个元素套用上述公式计算,并将计算结果累加,即为最终答案。

    int key;
    int val;
    UT_hash_handle hh;
};

int numRabbits(int* answers, int answersSize) {
    struct HashTable* hashTable = NULL;
    for (int i = 0; i < answersSize; i++) {
        struct HashTable* tmp;
        HASH_FIND_INT(hashTable, &answers[i], tmp);
        if (tmp == NULL) {
            tmp = malloc(sizeof(struct HashTable));
            tmp->key = answers[i];
            tmp->val = 1;
            HASH_ADD_INT(hashTable, key, tmp);
        } else {
            tmp->val++;
        }
    }
    int ans = 0;
    struct HashTable *iter, *tmp;
    HASH_ITER(hh, hashTable, iter, tmp) {
        int x = iter->val, y = iter->key;
        ans += (x + y) / (y + 1) * (y + 1);
    }
    return ans;
}

相关文章
|
JavaScript 前端开发 Python
leetcode每日一题 2021/4/4 781. 森林中的兔子
leetcode每日一题 2021/4/4 781. 森林中的兔子
67 0
|
8月前
有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问第n个月的兔子对数为多少?
有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问第n个月的兔子对数为多少?
106 3
|
4月前
兔子生崽
该程序解决经典的“兔子生崽”问题,假设兔子永不死亡,计算并打印前20个月的兔子总数。通过迭代计算每月兔子数量,采用斐波那契数列规律:1, 1, 2, 3, 5, 8, 13... (从第三个月起,每月数量等于前两个月之和)。程序每两个月输出一次结果,并更新数列中的值。
50 8
|
算法
趣味算法-神奇的兔子数列
趣味算法-神奇的兔子数列
|
C++
【LeetCode343】剪绳子(动态规划)
(1)确定状态 dp[i]是将正整数i拆成2个及其以上的正整数后,求所有数的乘积值。
148 0
【LeetCode343】剪绳子(动态规划)
|
存储 算法 调度
【喜闻乐见,包教包会】二分图最大匹配:匈牙利算法(洛谷P3386)
【喜闻乐见,包教包会】二分图最大匹配:匈牙利算法(洛谷P3386)
91 0
|
机器学习/深度学习
2022年9月月赛乙组 T2.树的直径
2022年9月月赛乙组 T2.树的直径
|
机器学习/深度学习
剑指offer 13. 剪绳子
剑指offer 13. 剪绳子
79 0

相关实验场景

更多