【leetcode12—–分糖果】

梦想不抛弃苦心追求的人,只要不停止追求,你们会沐浴在梦想的光辉之中。再美好的梦想与目标,再完美的计划和方案,如果不能尽快在行动中落实,最终只能是纸上谈兵,空想一番。只要瞄准了大方向,坚持不懈地做下去,才能够扫除挡在梦想前面的障碍,实现美好的人生蓝图。【leetcode12—–分糖果】,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

分糖果

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

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!