Day 9:2829. k-avoiding 数组的最小总和

Leetcode 2829. k-avoiding 数组的最小总和

给你两个整数 n 和 k 。

对于一个由 不同 正整数组成的数组,如果其中不存在任何求和等于 k 的不同元素对,则称其为 k-avoiding 数组。

返回长度为 n 的 k-avoiding 数组的可能的最小总和。

n 个不同正整数的最小总和,那就是从 1 到 n 的总和,但是还有一个要求就是不存在任何求和等于 k 的。因此接下来要删除掉这一部分数据。

从 1 开始判断,到 k / 2,删除和为 k 的最大的一个值,在加上一个 n 后的元素。

上述会有一个 bug,例如 n = 3, k =5 的情况,当判断 1 时,4 是不存在的,不用处理;当判断 2 时,删除 3,加一个 3 后面的数,也就是 4。此时又有 4 了,就会出现问题。

因此 ,从 k / 2 往 1 遍历,就不会出现判断时没有的元素,后来又被加上去的情况。因为判断会先删除小的,再删除大的。因此不会出现上述情况。

完整代码

java 复制代码
class Solution {
    public int minimumSum(int n, int k) {
        int res = 0;
        for (int i = 1; i <= n; i++) {
            res += i;
        }

        int removeCount = 0;
        for (int i = k / 2; i > 0; i--) {
            int tmp = k - i;
            if (tmp > (n + removeCount)) continue;
            if (tmp == i) continue;
            res -= tmp;
            removeCount++;
            res += n + removeCount;
        }
        return res;
    }
}
相关推荐
AI科技星21 小时前
光速飞行器动力学方程的第一性原理推导、验证与范式革命
数据结构·人工智能·线性代数·算法·机器学习·概率论
tao35566721 小时前
VS Code登录codex,报错(os error 10013)
java·服务器·前端
橘颂TA21 小时前
【剑斩OFFER】算法的暴力美学——leetCode 946 题:验证栈序列
c++·算法·leetcode·职场和发展·结构与算法
闻缺陷则喜何志丹21 小时前
【状态机动态规划】3686. 稳定子序列的数量|1969
c++·算法·动态规划·力扣·状态机动态规划
信创天地21 小时前
核心系统去 “O” 攻坚:信创数据库迁移的双轨运行与数据一致性保障方案
java·大数据·数据库·金融·架构·政务
mjhcsp21 小时前
C++ AC 自动机:原理、实现与应用全解析
java·开发语言·c++·ac 自动机
huihuihuanhuan.xin21 小时前
后端八股之java并发编程
java·开发语言
茶本无香21 小时前
设计模式之二—原型模式:灵活的对象克隆机制
java·设计模式·原型模式
寻星探路21 小时前
【算法通关】双指针技巧深度解析:从基础到巅峰(Java 最优解)
java·开发语言·人工智能·python·算法·ai·指针
wen__xvn21 小时前
力扣第 484 场周赛
算法·leetcode·职场和发展