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;
}

相关文章
|
6月前
|
JavaScript 前端开发 Python
leetcode每日一题 2021/4/4 781. 森林中的兔子
leetcode每日一题 2021/4/4 781. 森林中的兔子
37 0
|
9月前
|
算法
563. 二叉树的坡度【我亦无他唯手熟尔】
563. 二叉树的坡度【我亦无他唯手熟尔】
32 0
|
6月前
兔子问题
兔子问题。
27 1
|
7月前
|
算法
趣味算法-神奇的兔子数列
趣味算法-神奇的兔子数列
|
8月前
|
算法 测试技术
畅通工程 (最小生成树)
畅通工程 (最小生成树)
32 0
|
10月前
|
算法
食物链问题(并查集)
食物链问题(并查集)
67 0
|
算法 JavaScript 前端开发
日拱算法,森林中的兔子问题
森林中有未知数量的兔子。提问其中若干只兔子 "还有多少只兔子与你(指被提问的兔子)颜色相同?" ,将答案收集到一个整数数组 answers 中,其中 answers[i] 是第 i 只兔子的回答。
J - 食物链 POJ - 1182
J - 食物链 POJ - 1182
67 0
LeetCode每日一题(11)——太平洋大西洋水流问题(递归,深度优先遍历实例)
大西洋太平洋水流问题 1.题目 2.示例 3.思路 理解题目 解题思路 4.代码
110 0
LeetCode每日一题(11)——太平洋大西洋水流问题(递归,深度优先遍历实例)