freeCodecamp javaScript基础最后一题
使用递归来创建一个数字序列
已经定义好了 rangeOfNumbers 函数,包含两个参数。 函数应该返回一个连续数字数组,startNum 参数开始 endNum 参数截止。 开始的数字小于或等于截止数字。 函数必需递归调用自身,不能使用任意形式的循环。 要考虑到 startNum 和 endNum 相同的情况。
题目要求是要在数组中输出 [startNum,endNum] 这个区间的整数,如果rangeOfNumbers(1, 5),就要输出数组[1,2,3,4,5]
如果相等就输出值为startNum或者endNum的数组,即rangeOfNumbers(5, 5),就输出 [5]
function rangeOfNumbers(startNum, endNum) {
if(startNum==endNum) {return [startNum];}
else{
const numArray=rangeOfNumbers(startNum, endNum-1);
numArray.push(endNum);
return numArray;
}
};
需要注意的是在递归调用返回之后,推送才最后一次发生。
以rangeOfNumbers(1, 5)为例,
执行到rangeOfNumbers(1,5-1)后,还会执行rangeOfNumbers(1,5-1)…直到startNum=endNum,返回[startNum]这个数组,再由这个数组一层层向上返回,就会输出最后的结果。
这里还有两个方法很重要:
1.push() 往数组后面添加元素
2.unshift() 是添加元素到数组头部。