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

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

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

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

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

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

  • 思路
    使用大顶堆存放所有礼物,每次将堆顶元素移出,并将其平方根放入堆中,最后求出堆中剩余礼物数目
  • 实现
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 )

目录
打赏
0
0
0
0
5
分享
相关文章
|
10月前
|
【每日一题Day190】LC1172餐盘栈 | 优先队列
【每日一题Day190】LC1172餐盘栈 | 优先队列
91 0
|
10月前
【每日一题Day272】LC1499满足不等式的最大值 | 单调队列 大顶堆
【每日一题Day272】LC1499满足不等式的最大值 | 单调队列 大顶堆
40 0
|
10月前
【每日一题Day179】LC1157子数组中占绝大多数的元素 | 线段树
【每日一题Day179】LC1157子数组中占绝大多数的元素 | 线段树
70 0
最小堆最大堆了解吗?一文了解堆在前端中的应用
该文章详细解释了堆数据结构(特别是最小堆)的概念与性质,并提供了使用JavaScript实现最小堆的具体代码示例,包括堆的插入、删除等操作方法。
最小堆最大堆了解吗?一文了解堆在前端中的应用
|
10月前
|
【每日一题Day276】LC2208将数组和减半的最少操作次数 | 贪心+大顶堆
【每日一题Day276】LC2208将数组和减半的最少操作次数 | 贪心+大顶堆
62 0
|
10月前
【每日一题Day220】LC1439有序矩阵中的第 k 个最小数组和 | 堆
【每日一题Day220】LC1439有序矩阵中的第 k 个最小数组和 | 堆
92 0
[leetcode] 面试题 17.20. 连续中值 | 对顶堆维护动态中位数
[leetcode] 面试题 17.20. 连续中值 | 对顶堆维护动态中位数
116 0
【八月】 每日一题 - 768. 最多能完成排序的块 I and II
【八月】 每日一题 - 768. 最多能完成排序的块 I and II
134 0
【八月】 每日一题 - 768. 最多能完成排序的块 I and II
堆 最小堆 最大堆 堆排序(小到大,大到小)
堆 最小堆 最大堆 堆排序(小到大,大到小)
堆 最小堆 最大堆 堆排序(小到大,大到小)