【每日一题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)
相关推荐
敲代码的嘎仔6 小时前
力扣高频SQL基础50题详解
开发语言·数据库·笔记·sql·算法·leetcode·后端开发
洛水水8 小时前
【力扣100题】46.单词拆分
算法·leetcode·职场和发展
alphaTao10 小时前
LeetCode 每日一题 2026/5/11-2026/5/17
算法·leetcode
洛水水10 小时前
【力扣100题】45.零钱兑换
算法·leetcode·职场和发展
YL2004042611 小时前
041二叉树的层序遍历
数据结构·leetcode·bfs
洛水水12 小时前
【力扣100题】47.最长递增子序列
算法·leetcode·职场和发展
_日拱一卒14 小时前
LeetCode:199二叉树的右视图
算法·leetcode·职场和发展
人道领域14 小时前
【LeetCode刷题日记】递归与回溯实战 257.二叉树的所有路径——一篇文章彻底搞懂回溯
开发语言·python·算法·leetcode
ulias21214 小时前
leetcode热题 - 7
数据结构·算法·leetcode
玛卡巴卡ldf14 小时前
【LeetCode 手撕算法】(动态规划)爬楼梯、杨辉三角、打家劫舍、完全平方数、零钱兑换、单词拆分、最长递增子序列、乘积最大子数组、分割等和子集
java·数据结构·算法·leetcode·动态规划·力扣