给你一个整数数组 nums
,一个整数 k
和一个整数 multiplier
。
你需要对 nums
执行 k
次操作,每次操作中:
找到
nums
中的 最小 值x
,如果存在多个最小值,选择最 前面 的一个。将
x
替换为x * multiplier
。
k
次操作以后,你需要将 nums
中每一个数值对 109 + 7
取余。
请你返回执行完 k
次乘运算以及取余运算之后,最终的 nums
数组。
示例 1:
输入: nums = [2,1,3,5,6], k = 5, multiplier = 2
输出: [8,4,6,5,6]
解释:
操作 | 结果
---|---
1 次操作后 | [2, 2, 3, 5, 6]
2 次操作后 | [4, 2, 3, 5, 6]
3 次操作后 | [4, 4, 3, 5, 6]
4 次操作后 | [4, 4, 6, 5, 6]
5 次操作后 | [8, 4, 6, 5, 6]
取余操作后 | [8, 4, 6, 5, 6]
示例 2:
输入: nums = [100000,2000], k = 2, multiplier = 1000000
输出: [999999307,999999993]
解释:
操作 | 结果
---|---
1 次操作后 | [100000, 2000000000]
2 次操作后 | [100000000000, 2000000000]
取余操作后 | [999999307, 999999993]
提示:
1 <= nums.length <= 104
1 <= nums[i] <= 109
1 <= k <= 109
1 <= multiplier <= 106
K 次乘运算后的最终数组 II
题目
给你一个整数数组 nums
,一个整数 k
和一个整数 multiplier
。
你需要对 nums
执行 k
次操作,每次操作中:
- 找到
nums
中的 最小 值x
,如果存在多个最小值,选择最 前面 的一个。 - 将
x
替换为x * multiplier
。
k
次操作以后,你需要将 nums
中每一个数值对 109 + 7
取余。
请你返回执行完 k
次乘运算以及取余运算之后,最终的 nums
数组。
示例 1:
输入: nums = [2,1,3,5,6], k = 5, multiplier = 2
输出: [8,4,6,5,6]
解释:
操作 | 结果 |
---|---|
1 次操作后 | [2, 2, 3, 5, 6] |
2 次操作后 | [4, 2, 3, 5, 6] |
3 次操作后 | [4, 4, 3, 5, 6] |
4 次操作后 | [4, 4, 6, 5, 6] |
5 次操作后 | [8, 4, 6, 5, 6] |
取余操作后 | [8, 4, 6, 5, 6] |
示例 2: |
输入: nums = [100000,2000], k = 2, multiplier = 1000000
输出: [999999307,999999993]
解释:
操作 | 结果 |
---|---|
1 次操作后 | [100000, 2000000000] |
2 次操作后 | [100000000000, 2000000000] |
取余操作后 | [999999307, 999999993] |
提示:
1 <= nums.length <= 104
1 <= nums[i] <= 109
1 <= k <= 109
1 <= multiplier <= 106
题解
方法一:
思路
每次优先选择最小的乘以multiplier
。
当所有数都至少乘以过一次multiplier
,接下来的选择是n个数中轮流选择乘以multiplier
。
先记录nums
中最大值的下标mx。然后用优先队列不断选择取出最小值乘以multiplier
再放回,并减少k一次。直到下标为mx的数也乘以过一次multiplier
。这个过程在multiplier != 1
情况下只需要$min(nlog(n), k)$次堆操作。multiplier = 1
则可以直接将原数组作为答案。
此后每个数至少需要再乘以$multiplier^{\lfloor \frac{k}{n} \rfloor}$
另外优先队列中最小的$k \mod n$个数需要再多乘以一次multiplier
。
代码
1 | class Solution { |