LeetCode-575. 分糖果【数组 哈希表】

LeetCode-575. 分糖果【数组 哈希表】

题目描述:

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 种糖。

提示:

n == candyType.length

2 <= n <= 104

n 是一个偶数

-105 <= candyType[i] <= 105

解题思路一:用一个哈希set记录candyType有多少种糖果,返回Math.min(max_cnt, set.size());

python 复制代码
class Solution {
    public int distributeCandies(int[] candyType) {
        int n = candyType.length;
        int max_cnt = n / 2;
        Set<Integer> set = new HashSet<>();
        for(int i=0;i<n;i++){
            set.add(candyType[i]);
        }
        return Math.min(max_cnt, set.size());
    }
}

时间复杂度:O(n)

空间复杂度:O(n)

解题思路二:简化版

python 复制代码
class Solution {
    public int distributeCandies(int[] candyType) {
        Set<Integer> set = new HashSet<>();
        for(int candy: candyType){
            set.add(candy);
        }
        return Math.min(candyType.length / 2, set.size());
    }
}

时间复杂度:O(n)

空间复杂度:O(n)

解题思路三:

python 复制代码
class Solution:
    def distributeCandies(self, candyType: List[int]) -> int:
        return min(len(set(candyType)), len(candyType) // 2)

时间复杂度:O(n)

空间复杂度:O(n)


创作不易,观众老爷们请留步... 动起可爱的小手,点个赞再走呗 (๑◕ܫ←๑) 欢迎大家关注笔者,你的关注是我持续更博的最大动力

原创文章,转载告知,盗版必究




♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠ ⊕ ♠

相关推荐
明洞日记21 小时前
【VTK手册017】 深入详解 vtkImageMathematics:医学图像的基本算术运算
c++·图像处理·算法·vtk·图形渲染
程序员-周李斌21 小时前
CopyOnWriteArrayList 源码分析
java·开发语言·哈希算法·散列表
杰瑞不懂代码21 小时前
【公式推导】AMP算法比BP算法强在哪(一)
python·算法·机器学习·概率论
晚风(●•σ )21 小时前
C++语言程序设计——【算法竞赛常用知识点】
开发语言·c++·算法
浅川.2521 小时前
xtuoj 哈希
算法·哈希算法·散列表
AndrewHZ21 小时前
【复杂网络分析】复杂网络分析技术在图像处理中的经典算法与应用实践
图像处理·人工智能·算法·计算机视觉·图像分割·复杂网络·图论算法
free-elcmacom21 小时前
机器学习入门<4>RBFN算法详解
开发语言·人工智能·python·算法·机器学习
java修仙传21 小时前
力扣hot100:最长连续序列
算法·leetcode·职场和发展
zore_c21 小时前
【C语言】文件操作详解3(文件的随机读写和其他补充)
c语言·开发语言·数据结构·笔记·算法
Pluchon21 小时前
硅基计划4.0 算法 记忆化搜索
java·数据结构·算法·leetcode·决策树·深度优先