当我们看到“重写函数让其无限相加”这个题目时,第一时间想到的就是递归。递归是指函数直接或间接地调用自身。使用递归可以很方便地实现一个无限相加的函数。
下面是一个实现步骤的完整攻略:
1. 定义函数
首先,我们需要定义一个函数,函数名为add
,参数为无限个数字,返回值为一个函数。
function add() {
let args = Array.prototype.slice.call(arguments);
function sum() {
let innerArgs = Array.prototype.slice.call(arguments);
args = args.concat(innerArgs);
return sum; // 返回函数
}
sum.toString = function() {
return args.reduce(function(a, b) {
return a + b;
});
}
return sum;
}
参数使用arguments
来获取,将参数转换为数组,方便后续操作。
在函数内部,定义了一个名为sum
的函数,用于记录参数之和,并返回sum
函数本身。
最后,为sum
函数添加一个toString
方法,当在调用的时候直接返回之和。
2. 使用示例
下面是两个示例,用于说明使用该函数的方法:
示例一
add(1)(2)(3) // 6
在这个示例中,我们通过连续调用函数的方式,将1, 2, 3
三个数作为参数依次传入,最后返回的结果为它们的和6
。
示例二
add(1)(2)(3)(4)(5) // 15
在这个示例中,我们同样使用了连续调用函数的方式,将1, 2, 3, 4, 5
五个数依次传入,最后返回的结果为它们的和15
。
3. 总结
以上就是关于“重写函数让其无限相加”的完整攻略,通过递归的方式实现了连续输入无限数量的数之后求和的需求。注意,在使用时需要在每个数之间使用 ()
调用函数,否则就会返回一个返回下一个函数的函数,而不是结果。
本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:javascript题目,重写函数让其无限相加 - Python技术站