gpt4 book ai didi

javascript - 尝试理解 JS 中的递归...检查我的简单代码

转载 作者:行者123 更新时间:2023-12-02 01:24:08 25 4
gpt4 key购买 nike

我正在尝试理解递归函数。我尝试了一些入门级练习,但没有成功。例如,我将这段代码放入 JS fiddle 中。我打算让它计算从 1 到 n 的所有数字的总和。

function sumAll(n) {
if (n == 1 ) {
return 1;
} else if (n > 1) {
return sumAll(n--) + n;
}
}

console.log(sumAll(3));

向函数输入 3 应该会得到“6”。但我收到一个错误。

最佳答案

-- 后缀运算符将计算出 n原始值,以及从 n 中减去的值之后会发生(这也是不希望的,因为您仍然想要执行 + n )。这意味着递归调用获得的 n 值与调用者相同,因此您不会更接近结束...

这里不要使用--,而是使用-1:

function sumAll(n) {
if (n == 1 ) {
return 1;
}
else if (n > 1) {
return sumAll(n-1) + n;
}
}

console.log(sumAll(3));

关于javascript - 尝试理解 JS 中的递归...检查我的简单代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/75236680/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com