题目描述
这是 LeetCode 上的 575. 分糖果 ,难度为 简单。
Tag : 「贪心」
给定一个偶数长度的数组,其中不同的数字代表着不同种类的糖果,每一个数字代表一个糖果。你需要把这些糖果平均分给一个弟弟和一个妹妹。
返回妹妹可以获得的最大糖果的种类数。
示例 1:
输入: candies = [1,1,2,2,3,3]
输出: 3
解析: 一共有三种种类的糖果,每一种都有两个。
最优分配方案:妹妹获得[1,2,3],弟弟也获得[1,2,3]。这样使妹妹获得糖果的种类数最多。
示例 2 :
输入: candies = [1,1,2,3]
输出: 2
解析: 妹妹获得糖果[2,3],弟弟获得糖果[1,1],妹妹有两种不同的糖果,弟弟只有一种。这样使得妹妹可以获得的糖果种类数最多。
注意:
- 数组的长度为[2, 10,000],并且确定为偶数。
- 数组中数字的大小在范围[-100,000, 100,000]内。
贪心
由于题目规定糖果数量 为偶数,因此一定能将糖果平均分配成两份,每份数量固定为 。
假设糖果种类数量为 ,那么单份中可使得糖果种类数量最大为 。
可以使用「分情况讨论」进行证明:
- :糖果种类大于单份的糖果数量。此时可以从 类糖果中找出 类不同的糖果组成单份,此时可取得的最大种类数量为 ;
- :糖果种类等于单份的糖果数量。同理,此时可以从 类糖果中找出 类不同的糖果组成单份,此时可取得的最大种类数量为 ;
- :糖果种类小于单份的糖果数量。此时先从 类糖果中找出 类不同糖果组成单份,再使用相同种类的糖果凑齐 ,此时可取得的最大种类数量为 。
综上,无论糖果种类数与单份糖果数呈何种关系,我们可取得的最大糖果种类数量均为 。
代码:
class Solution {
public int distributeCandies(int[] candyType) {
Set<Integer> set = new HashSet<>();
for (int i : candyType) set.add(i);
return Math.min(candyType.length / 2, set.size());
}
}
- 时间复杂度:
- 空间复杂度:
最后
这是我们「刷穿 LeetCode」系列文章的第 No.575
篇,系列开始于 2021/01/01,截止于起始日 LeetCode 上共有 1916 道题目,部分是有锁题,我们将先把所有不带锁的题目刷完。
在这个系列文章里面,除了讲解解题思路以外,还会尽可能给出最为简洁的代码。如果涉及通解还会相应的代码模板。
为了方便各位同学能够电脑上进行调试和提交代码,我建立了相关的仓库:github.com/SharingSour… 。
在仓库地址里,你可以看到系列文章的题解链接、系列文章的相应代码、LeetCode 原题链接和其他优选题解。