分糖果
Alice 有 n 枚糖,其中第 i 枚糖的类型为 candyType[i] 。Alice 注意到她的体重正在增长,所以前去拜访了一位医生。
医生建议 Alice 要少摄入糖分,只吃掉她所有糖的 n / 2 即可(n 是一个偶数)。Alice 非常喜欢这些糖,她想要在遵循医生建议的情况下,尽可能吃到最多不同种类的糖。
给你一个长度为 n 的整数数组 candyType ,返回: Alice 在仅吃掉 n / 2 枚糖的情况下,可以吃到糖的 最多 种类数。
示例 1:
输入:candyType = [1,1,2,2,3,3]
输出:3
解释:Alice 只能吃 6 / 2 = 3 枚糖,由于只有 3 种糖,她可以每种吃一枚。
示例 2:
输入:candyType = [1,1,2,3]
输出:2
解释:Alice 只能吃 4 / 2 = 2 枚糖,不管她选择吃的种类是 [1,2]、[1,3] 还是 [2,3],她只能吃到两种不同类的糖。
示例 3:
输入:candyType = [6,6,6,6]
输出:1
解释:Alice 只能吃 4 / 2 = 2 枚糖,尽管她能吃 2 枚,但只能吃到 1 种糖。
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/distribute-candies
题解一:
官解果然简单明了,如果糖的种类x大于Alice可以吃的糖的数量num,则Alice只能吃num种,如果糖的种类x小于Alice可以吃的糖的数量num,则Alice只能吃x种,所以Alice能吃到的糖的种类是min(x,num)。代码如下:
class Solution {
public int distributeCandies(int[] candyType) {
//Set集合不允许元素重复,所以Set集合元素的个数就是糖果的种类
Set<Integer> set = new HashSet<Integer>();
for (int candy : candyType) {
set.add(candy);
}
return Math.min(set.size(), candyType.length / 2);
}
}
题解二:
笔者的解就比较低效率了,还是写的代码不够多。首先对糖果种类集合排序,然后遍历记录糖果种类的个数,最后把糖果种类与Alice可以吃的数量比较,然后返回。代码如下:
class Solution {
public int distributeCandies(int[] candyType) {
int num=candyType.length/2;
int x=1;
Arrays.sort(candyType);
int val=candyType[0];
for(int i=1;i<candyType.length;i++){
if(val!=candyType[i]){
x++;
val=candyType[i];
}
}
if(num>=x){
return x;
}else{
return num;
}
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/153956.html