【每日一题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)
相关推荐
不7夜宵4 小时前
力扣热题100 k个一组反转链表题解
算法·leetcode·链表
蒟蒻小袁5 小时前
力扣面试150题--课程表
算法·leetcode·面试
AL流云。6 小时前
【优选算法】分治
数据结构·算法·leetcode·排序算法
chengooooooo13 小时前
leetcode Top100 238. 除自身以外数组的乘积|数组系列
算法·leetcode
GalaxyPokemon16 小时前
LeetCode - 53. 最大子数组和
算法·leetcode·职场和发展
hn小菜鸡17 小时前
LeetCode 1356.根据数字二进制下1的数目排序
数据结构·算法·leetcode
zhuiQiuMX17 小时前
分享今天做的力扣SQL题
sql·算法·leetcode
全栈凯哥20 小时前
Java详解LeetCode 热题 100(26):LeetCode 142. 环形链表 II(Linked List Cycle II)详解
java·算法·leetcode·链表
全栈凯哥20 小时前
Java详解LeetCode 热题 100(27):LeetCode 21. 合并两个有序链表(Merge Two Sorted Lists)详解
java·算法·leetcode·链表