递归:我的函数在哪里出错?

问题描述 投票:1回答:2

所以我正在解决CodeWars kata。

链接至Kata:https://www.codewars.com/kata/5ce399e0047a45001c853c2b/train/javascript

这是我的代码:

function partsSums(arr) {
    let bigSum = [];
    if (arr.length == 0) {
        bigSum.push(0);
    }

    while (arr.length >= 1) {
        let sum = arr.reduce((acc, ele) => acc + ele);
        bigSum.push(sum);
        partsSums(arr.shift());
    }

    return bigSum;
}

正确答案应该是:[20, 20, 19, 16, 10, 0]

我的函数返回:[ 20, 20, 19, 16, 10 ]

请指出我错了或我的误解。谢谢!

javascript arrays algorithm function recursion
2个回答
4
投票

您可以从右侧减少并在索引零处添加该值。

function partsSums(arr) {
    return arr.reduceRight((r, value) => [r[0] + value, ...r], [0]);
}

console.log(partsSums([0, 1, 3, 6, 10]));

快速版本

function partsSums(ls) {
    let l = ls.length,
        result = [];

    result[l] = 0;

    while (l--) result[l] = result[l + 1] + ls[l];

    return result;
}

console.log(partsSums([0, 1, 3, 6, 10]));

1
投票

问题是,当数组在循环中达到长度0时,实际上并没有向bigSum附加任何内容。您可以通过在循环后将其显式添加来实现。

function partsSums(arr) {
    let bigSum = [];

    while (arr.length >= 1) {
        let sum = arr.reduce((acc, ele) => acc + ele);
        bigSum.push(sum);
        partsSums(arr.shift());
    }
    
    bigSum.push(0);

    return bigSum;
}
console.log(partsSums([0, 1, 3, 6, 10]));
© www.soinside.com 2019 - 2024. All rights reserved.