[leetcode/lintcode 题解] 阿里算法面试真题:森林中的兔子

简介: [leetcode/lintcode 题解] 阿里算法面试真题:森林中的兔子

描述
在一个森林中,每个兔子都有一种颜色。兔子中的一部分(也可能是全部)会告诉你有多少兔子和它们有同样的颜色。这些答案被放在了一个数组中。
返回森林中兔子可能的最少的数量。

  1. 给定数组的长度不超过 1000.
  2. 数组内的每个元素的范围都在 [0, 999]中.

在线评测地址:领扣题库官网

样例1
输入: [1, 1, 2]
输出: 5
解释:
  两个回答 "1" 的兔子可能是相同的颜色,姑且说它们为红色.
  回答 "2" 的兔子一定不会是红色,不然与前面的答案冲突.
  姑且认为回答 "2" 的兔子是蓝色.
  那么一定还有 2 只蓝色的兔子在森林里不过没有回答问题.
  所以森林里兔子的最少总数是 5, 3只回答问题的加上 2 只没回答的.
样例2
输入: [10, 10, 10]
输出: 11

解题思路
假如说一只兔子说有 x 只兔子颜色与自己相同, 那么可以说有 x + 1 只兔子是这种颜色.
假如说共有 a 只兔子说有 b 只兔子与自己颜色相同, 那么暂且可以认为它们是同一种颜色:

  • 如果 a == b + 1 那么我们可以认为说话了的这a只兔子就是所有这种颜色的兔子
  • 如果 a < b + 1 那么说明还有 b + 1 - a 只这种颜色的兔子并没有说话
  • 如果 a > b + 1 那么说明不只一种颜色, 可以认为每 b + 1 只是一种颜色

所以, 我们的处理方式便是:

  1. 把数组中的每个数字都 + 1
  2. 统计数组中每个数字的数量
  3. 假设数组中的 a 有 b 个, 那么这b个a对应的最少的兔子的数量就是 ceil(b / a) * a

可以这样做是因为: 为了让总数最小, 我们总是尽可能认为两只兔子是同一颜色, 而说出了不同的数字的兔子必然不是同一颜色的.

class Solution {
        public int numRabbits(int[] answers) {
                int res = 0;
                Map<Integer,Integer> map = new HashMap<>();
                for(int answer : answers) {
                        map.put(answer,map.getOrDefault(answer,0)+1);
                }
                for(Integer n : map.keySet()) {
                        int group = map.get(n)/(n+1);
                        res += map.get(n)%(n+1) != 0 ? (group+1)*(n+1) : group*(n+1);
                }
                return res;
        }
}

更多题解参考:九章官网solution

相关文章
|
算法
面试场景题:如何设计一个抢红包随机算法
本文详细解析了抢红包随机算法的设计与实现,涵盖三种解法:随机分配法、二倍均值法和线段切割法。随机分配法通过逐次随机分配金额确保总额不变,但易导致两极分化;二倍均值法优化了金额分布,使每次抢到的金额更均衡;线段切割法则将总金额视为线段,通过随机切割点生成子金额,手气最佳金额可能更高。代码示例清晰,结果对比直观,为面试中类似算法题提供了全面思路。
1921 16
|
算法 安全 Java
Java线程调度揭秘:从算法到策略,让你面试稳赢!
在社招面试中,关于线程调度和同步的相关问题常常让人感到棘手。今天,我们将深入解析Java中的线程调度算法、调度策略,探讨线程调度器、时间分片的工作原理,并带你了解常见的线程同步方法。让我们一起破解这些面试难题,提升你的Java并发编程技能!
587 16
|
算法 Java 数据库
美团面试:百亿级分片,如何设计基因算法?
40岁老架构师尼恩分享分库分表的基因算法设计,涵盖分片键选择、水平拆分策略及基因法优化查询效率等内容,助力面试者应对大厂技术面试,提高架构设计能力。
美团面试:百亿级分片,如何设计基因算法?
|
算法 前端开发 Java
数据结构与算法学习四:单链表面试题,新浪、腾讯【有难度】、百度面试题
这篇文章总结了单链表的常见面试题,并提供了详细的问题分析、思路分析以及Java代码实现,包括求单链表中有效节点的个数、查找单链表中的倒数第k个节点、单链表的反转以及从尾到头打印单链表等题目。
211 1
数据结构与算法学习四:单链表面试题,新浪、腾讯【有难度】、百度面试题
|
机器学习/深度学习 算法 Java
机器学习、基础算法、python常见面试题必知必答系列大全:(面试问题持续更新)
机器学习、基础算法、python常见面试题必知必答系列大全:(面试问题持续更新)
|
算法 Java 数据库
美团面试:百亿级分片,如何设计基因算法?
40岁老架构师尼恩在读者群中分享了关于分库分表的基因算法设计,旨在帮助大家应对一线互联网企业的面试题。文章详细介绍了分库分表的背景、分片键的设计目标和建议,以及基因法的具体应用和优缺点。通过系统化的梳理,帮助读者提升架构、设计和开发水平,顺利通过面试。
美团面试:百亿级分片,如何设计基因算法?
|
6月前
|
机器学习/深度学习 算法 机器人
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
575 0
|
6月前
|
数据采集 分布式计算 并行计算
mRMR算法实现特征选择-MATLAB
mRMR算法实现特征选择-MATLAB
368 2
|
7月前
|
传感器 机器学习/深度学习 编解码
MATLAB|主动噪声和振动控制算法——对较大的次级路径变化具有鲁棒性
MATLAB|主动噪声和振动控制算法——对较大的次级路径变化具有鲁棒性
320 3
|
6月前
|
机器学习/深度学习 算法 机器人
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
282 8