算法(TS):找出数组中和为sum的n个数

使用递归和回溯

ts 复制代码
function findSum(arr: number[],target:number,count:number):number[][] {
    if(arr.length === 0 || count <= 0) return []
    const answers: number[][] = []
    const current: number[] = []

    const backtrack = (start: number,sum: number,n: number) => {
        if(sum === 0 && n === 0) {
            answers.push([...current])
            return
        }

        for(let i = start; i < arr.length; i++) {
            if(arr[i] <= sum) {
                current.push(arr[i])
                backtrack(i + 1,sum-arr[i],n-1)
                current.pop()
            }
        }
    }

    backtrack(0,target,count)
    return answers

}
相关推荐
weixin_4296302612 分钟前
实验二-决策树-葡萄酒
算法·决策树·机器学习
JS.Huang35 分钟前
【JavaScript】原生函数
开发语言·javascript·ecmascript
茉莉玫瑰花茶1 小时前
floodfill 算法(dfs)
算法·深度优先
533_1 小时前
[vue] dayjs 显示实时时间
前端·javascript·vue.js
CoderCodingNo1 小时前
【GESP】C++五级考试大纲知识点梳理, (5) 算法复杂度估算(多项式、对数)
开发语言·c++·算法
MYX_3092 小时前
第三章 线型神经网络
深度学习·神经网络·学习·算法
ftpeak2 小时前
JavaScript性能优化实战
开发语言·javascript·性能优化
一个很帅的帅哥2 小时前
JavaScript事件循环
开发语言·前端·javascript
云枫晖3 小时前
Webapck系列-初识Webpack
前端·javascript
坚持编程的菜鸟3 小时前
LeetCode每日一题——三角形的最大周长
算法·leetcode·职场和发展