【每日一题Day361】LC2558从数量最多的堆取走礼物 | 大顶堆

从数量最多的堆取走礼物【LC2558】

给你一个整数数组 gifts ,表示各堆礼物的数量。每一秒,你需要执行以下操作:

  • 选择礼物数量最多的那一堆。
  • 如果不止一堆都符合礼物数量最多,从中选择任一堆即可。
  • 选中的那一堆留下平方根数量的礼物(向下取整),取走其他的礼物。

返回在 k 秒后剩下的礼物数量*。*

  • 思路

    使用大顶堆存放所有礼物,每次将堆顶元素移出,并将其平方根放入堆中,最后求出堆中剩余礼物数目

  • 实现

    java 复制代码
    class Solution {
        public long pickGifts(int[] gifts, int k) {
            long res = 0L;
            PriorityQueue<Integer> pq = new PriorityQueue<>((o1, o2) -> o2 - o1);
            for (int gift :gifts){
                pq.add(gift);
                res += gift;
            }
            while(k-- > 0){
                int poll = pq.poll(), left = (int)Math.sqrt(poll);
                res -= poll - left;
                pq.add(left);
            }
            return res;
        }
    }
    • 复杂度
      • 时间复杂度: O ( n + k l o g n ) O(n+klogn) O(n+klogn)
      • 空间复杂度: O ( n ) O(n) O(n)
相关推荐
sheeta199839 分钟前
LeetCode 每日一题笔记 日期:2026.04.21 题目:1722. 执行交换操作后的最小汉明距离
笔记·算法·leetcode
玛丽莲茼蒿2 小时前
Leetcode hot100 买卖股票的最佳时机【简单】
算法·leetcode·职场和发展
阿Y加油吧2 小时前
两道 LeetCode 题的复盘笔记:从「只会暴力」到「懂优化」
笔记·算法·leetcode
We་ct2 小时前
LeetCode 300. 最长递增子序列:两种解法从入门到优化
开发语言·前端·javascript·算法·leetcode·typescript
始三角龙3 小时前
LeetCode hoot 100 -- 找到字符串中的所有字母异位词
算法·leetcode·职场和发展
abant23 小时前
leetcode 45 跳跃问题2 很难的贪心
算法·leetcode·职场和发展
水木流年追梦4 小时前
CodeTop Top 100 热门题目(按题型分类)
算法·leetcode
Tisfy5 小时前
LeetCode 1722.执行交换操作后的最小汉明距离:连通图
算法·leetcode·dfs·题解·深度优先搜索·连通图
样例过了就是过了5 小时前
LeetCode热题100 杨辉三角
c++·算法·leetcode·动态规划
eggrall5 小时前
Leetcode 最大连续 1 的个数 III(medium)
算法·leetcode·职场和发展