【每日一题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)
相关推荐
小丁爱养花37 分钟前
记忆化搜索专题——算法简介&力扣实战应用
java·开发语言·算法·leetcode·深度优先
楠枬3 小时前
双指针算法
java·算法·leetcode
sjsjs113 小时前
【数据结构-差分】力扣1589. 所有排列中的最大和
数据结构·算法·leetcode
孙小二写代码4 小时前
[leetcode刷题]面试经典150题之4删除有序数组中的重复项II(中等)
算法·leetcode·面试
西柚与蓝莓5 小时前
922. 按奇偶排序数组 II 双指针 力扣
数据结构·算法·leetcode
Amor风信子5 小时前
【力扣】2376. 统计特殊整数
算法·leetcode·职场和发展
杰九14 小时前
【算法题】46. 全排列-力扣(LeetCode)
算法·leetcode·深度优先·剪枝
manba_14 小时前
leetcode-560. 和为 K 的子数组
数据结构·算法·leetcode
liuyang-neu14 小时前
力扣 11.盛最多水的容器
算法·leetcode·职场和发展
忍界英雄14 小时前
LeetCode:2398. 预算内的最多机器人数目 双指针+单调队列,时间复杂度O(n)
算法·leetcode·机器人