comments | difficulty | edit_url | rating | source | tags | ||||
---|---|---|---|---|---|---|---|---|---|
true |
中等 |
1658 |
第 283 场周赛 Q2 |
|
给你一个整数数组 nums
和一个整数 k
。请你向 nums
中追加 k
个 未 出现在 nums
中的、互不相同 的 正 整数,并使结果数组的元素和 最小 。
返回追加到 nums
中的 k
个整数之和。
示例 1:
输入:nums = [1,4,25,10,25], k = 2 输出:5 解释:在该解法中,向数组中追加的两个互不相同且未出现的正整数是 2 和 3 。 nums 最终元素和为 1 + 4 + 25 + 10 + 25 + 2 + 3 = 70 ,这是所有情况中的最小值。 所以追加到数组中的两个整数之和是 2 + 3 = 5 ,所以返回 5 。
示例 2:
输入:nums = [5,6], k = 6 输出:25 解释:在该解法中,向数组中追加的两个互不相同且未出现的正整数是 1 、2 、3 、4 、7 和 8 。 nums 最终元素和为 5 + 6 + 1 + 2 + 3 + 4 + 7 + 8 = 36 ,这是所有情况中的最小值。 所以追加到数组中的两个整数之和是 1 + 2 + 3 + 4 + 7 + 8 = 25 ,所以返回 25 。
提示:
1 <= nums.length <= 105
1 <= nums[i], k <= 109
我们不妨向数组中加入两个哨兵节点,分别为
然后我们对数组进行排序,那么对于数组中的任意两个相邻的元素
因此,我们从小到大遍历数组中的相邻元素对
时间复杂度
class Solution:
def minimalKSum(self, nums: List[int], k: int) -> int:
nums.extend([0, 2 * 10**9])
nums.sort()
ans = 0
for a, b in pairwise(nums):
m = max(0, min(k, b - a - 1))
ans += (a + 1 + a + m) * m // 2
k -= m
return ans
class Solution {
public long minimalKSum(int[] nums, int k) {
int n = nums.length;
int[] arr = new int[n + 2];
arr[1] = 2 * 1000000000;
System.arraycopy(nums, 0, arr, 2, n);
Arrays.sort(arr);
long ans = 0;
for (int i = 0; i < n + 1 && k > 0; ++i) {
int m = Math.max(0, Math.min(k, arr[i + 1] - arr[i] - 1));
ans += (arr[i] + 1L + arr[i] + m) * m / 2;
k -= m;
}
return ans;
}
}
class Solution {
public:
long long minimalKSum(vector<int>& nums, int k) {
nums.push_back(0);
nums.push_back(2e9);
sort(nums.begin(), nums.end());
long long ans = 0;
for (int i = 0; i < nums.size() - 1 && k > 0; ++i) {
int m = max(0, min(k, nums[i + 1] - nums[i] - 1));
ans += 1LL * (nums[i] + 1 + nums[i] + m) * m / 2;
k -= m;
}
return ans;
}
};
func minimalKSum(nums []int, k int) (ans int64) {
nums = append(nums, []int{0, 2e9}...)
sort.Ints(nums)
for i, b := range nums[1:] {
a := nums[i]
m := max(0, min(k, b-a-1))
ans += int64(a+1+a+m) * int64(m) / 2
k -= m
}
return ans
}
function minimalKSum(nums: number[], k: number): number {
nums.push(...[0, 2 * 10 ** 9]);
nums.sort((a, b) => a - b);
let ans = 0;
for (let i = 0; i < nums.length - 1; ++i) {
const m = Math.max(0, Math.min(k, nums[i + 1] - nums[i] - 1));
ans += Number((BigInt(nums[i] + 1 + nums[i] + m) * BigInt(m)) / BigInt(2));
k -= m;
}
return ans;
}