当前位置: 首页 > news >正文

leetcode每日一题——k-avoiding 数组的最小总和

给你两个整数 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 数组。

方法一:hash检测

function minimumSum(n: number, k: number): number {
    let sum = 0
    const set = new Set<Number>()
    for(let i = 1;n != 0; i++) {
        if (!set.has(k - i)) {
            set.add(i)
            sum += i
            n--
        }
    }
    return sum;
};

结果:

方法二:暴力法

function minimumSum(n: number, k: number): number {
    const list = new Array();
    loop:for (let i = 1; n != 0; i++) {
        for (let j = 0;j < list.length;j++){
            if (i + list[j] == k) {
                continue loop
            }
        }
        list.push(i)
        n--
    }
    return list.reduce((a, b) => a + b);
};

结果:

相关文章:

  • 主流软件工程模型全景剖析
  • 零拷贝原理面试回答
  • 【字符设备驱动开发–IMX6ULL】(二)Linux 设备号
  • 多模态交互下的车载机械臂体感控制系统设计与实现研究
  • 计算机网络基础:软件定义网络(SDN)深度解析
  • 使用 fetch 实现流式传输:核心原理与实践
  • 启幕数据结构算法雅航新章,穿梭C++梦幻领域的探索之旅——堆的应用之堆排、Top-K问题
  • 3.26 代码随想录第二十七天打卡
  • 参考文献格式对齐1-100
  • idea 快捷键
  • Harbor自建证书实现Https访问
  • LLVM学习-DragonEgg工具
  • 强化学习和智能决策:Q-Learning和Deep Q-Learning算法
  • 漫画|基于SprinBoot+vue的漫画网站(源码+数据库+文档)
  • 【0基础跟AI学软考高项】质量管理
  • PVE 安装黑苹果 MacOS
  • mac m3 pro 部署 stable diffusion webui
  • cJSON- API 深度解析:设计理念与实现原理(二)
  • 本地靶场的“作弊模式”?从单用户模式解锁网络与权限的秘密
  • 用Deepseek写扫雷uniapp小游戏
  • 美国失去最后一个AAA评级,资产价格怎么走?美股或将触及天花板
  • 美国失去最后的AAA主权评级,继标普、惠誉后再遭穆迪降级
  • 高途一季度净利润同比增长1108%: “与吴彦祖一起学英语”短时间内就实现了盈利
  • 专家:家长要以身作则,孩子是模仿者学习者有时也是评判者
  • 商务部:今年前3月自贸试验区进出口总额达2万亿元
  • 泽连斯基启程前往土耳其