给你两个整数 n
和 k
。
对于一个由 不同 正整数组成的数组,如果其中不存在任何求和等于 k 的不同元素对,则称其为 k-avoiding 数组。
返回长度为 n
的 k-avoiding 数组的可能的最小总和。
示例 1:
输入:n = 5, k = 4 输出:18 解释:设若 k-avoiding 数组为 [1,2,4,5,6] ,其元素总和为 18 。 可以证明不存在总和小于 18 的 k-avoiding 数组。
示例 2:
输入:n = 2, k = 6 输出:3 解释:可以构造数组 [1,2] ,其元素总和为 3 。 可以证明不存在总和小于 3 的 k-avoiding 数组。
提示:文章来源:https://www.toymoban.com/news/detail-662872.html
1 <= n, k <= 50
C++
文章来源地址https://www.toymoban.com/news/detail-662872.html
class Solution {
public:
int minimumSum(int n, int k) {
unordered_map<int,int> neg;
int res=0;
int i=1;
int count=0;
while(i<=n) {
if(neg.find(i)==neg.end()) {
res+=i;
count++;
if(k-i!=i) {
neg[k-i]=1;
}
}
i++;
}
while(count<n) {
if(neg.find(i)==neg.end()) {
count++;
res+=i;
}
i++;
}
return res;
}
};
到了这里,关于leetcode 6450. k-avoiding 数组的最小总和的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!