leetcode在力扣 App 中打开
调试中...
调试中...
题目描述
题目描述
题解
题解
提交记录
提交记录
代码
代码
测试用例
测试用例
测试结果
测试结果
中等
相关标签
相关企业
提示

给你一个下标从 0 开始的整数数组 nums ,它表示一个 ,其中 nums[0] 是堆顶的元素。

每一次操作中,你可以执行以下操作 之一 :

  • 如果堆非空,那么 删除 堆顶端的元素。
  • 如果存在 1 个或者多个被删除的元素,你可以从它们中选择任何一个,添加 回堆顶,这个元素成为新的堆顶元素。

同时给你一个整数 k ,它表示你总共需要执行操作的次数。

请你返回 恰好 执行 k 次操作以后,堆顶元素的 最大值 。如果执行完 k 次操作以后,堆一定为空,请你返回 -1 。

 

示例 1:

输入:nums = [5,2,2,4,0,6], k = 4
输出:5
解释:
4 次操作后,堆顶元素为 5 的方法之一为:
- 第 1 次操作:删除堆顶元素 5 ,堆变为 [2,2,4,0,6] 。
- 第 2 次操作:删除堆顶元素 2 ,堆变为 [2,4,0,6] 。
- 第 3 次操作:删除堆顶元素 2 ,堆变为 [4,0,6] 。
- 第 4 次操作:将 5 添加回堆顶,堆变为 [5,4,0,6] 。
注意,这不是最后堆顶元素为 5 的唯一方式。但可以证明,4 次操作以后 5 是能得到的最大堆顶元素。

示例 2:

输入:nums = [2], k = 1
输出:-1
解释:
第 1 次操作中,我们唯一的选择是将堆顶元素弹出堆。
由于 1 次操作后无法得到一个非空的堆,所以我们返回 -1 。

 

提示:

  • 1 <= nums.length <= 105
  • 0 <= nums[i], k <= 109
通过次数
11K
提交次数
48.4K
通过率
22.8%

相关标签

相关企业

提示 1
For each index i, how can we check if nums[i] can be present at the top of the pile or not after k moves?

提示 2
For which conditions will we end up with an empty pile?

相似题目
中等

评论 (0)

贡献者
© 2025 领扣网络(上海)有限公司
0 人在线
行 1,列 1
nums =
[5,2,2,4,0,6]
k =
4
Source