当前位置: 首页 > 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);
};

结果:

http://www.dtcms.com/a/91829.html

相关文章:

  • 主流软件工程模型全景剖析
  • 零拷贝原理面试回答
  • 【字符设备驱动开发–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小游戏
  • 【GPUStack】【dify】【RAGflow】:本地部署GPUStack并集成到dify和RAGflow
  • (基本常识)左值引用、右值引用、万能引用、移动语义和完美转发——原理和代码示例
  • Linux学习:进程通信(管道)
  • HarmonyOS:GridObjectSortComponent(两个Grid之间网格元素交换)
  • 微软下一个大更新:Windows 11 25H2或已在路上!
  • CSS(八)
  • Linux笔记---动静态库(使用篇)
  • 全书测试:《C++性能优化指南》
  • 如何在 Postman 中配置并发送 JSON 格式的 POST 请求?
  • ‌国产芯片解析:龙迅HDMI发射机系列产品详解