【每日一题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 分钟前
【Leetcode】移动零
算法·leetcode·职场和发展
人道领域10 分钟前
【LeetCode刷题日记】131.分割回文串,动态规划优化
java·开发语言·leetcode
Lsk_Smion3 小时前
力扣实训 _ [994].腐烂的橘子/图论
算法·leetcode·图论
8Qi83 小时前
LeetCode 337:打家劫舍 III(House Robber III)—— 题解 ✅
算法·leetcode·二叉树·动态规划
2601_961194023 小时前
教资科三美术考什么|初中高中美术题型考点和模板资料
leetcode·elasticsearch·职场和发展·蓝桥杯·pat考试·lucene
8Qi84 小时前
LeetCode 121 & 122:股票买卖问题(DP 对比题解)✅
算法·leetcode·职场和发展·动态规划
一只齐刘海的猫4 小时前
【Leetcode】 接雨水
java·算法·leetcode
菜菜的顾清寒5 小时前
力扣HOT(100)54多维动态规划-最长公共子序列
算法·leetcode·动态规划
8Qi87 小时前
LeetCode 198:打家劫舍(House Robber)—— 题解 ✅
算法·leetcode·动态规划
8Qi816 小时前
LeetCode 235. 二叉搜索树的最近公共祖先(LCA)
算法·leetcode·二叉树·递归·二叉搜索树·lca·迭代