1.什么是递归?
所谓的递归就是自己调用自己,采取函数调用函数自身的方式工作。
javascript中递归最典型的应用是求阶乘和波菲那契数列。
2.举个栗子:求1+2+3...+n的和?
利用for循环的方法计算出来:
function sum(n) {
var total = 0
for (var i = 1; i <= n; i++) {
total = total + i
}
return total
}
console.log(sum(3)); //得出6
function sum1(n) {
if (n === 1) { // 当n=1时,要给出终止条件
return 1;
}
return sum1(n - 1) + n;
}
console.log(sum1(3)); // 6
function fb(n){
if (n == 1 || n==2) { // 从第三项开始
return 1
}
return fb(n-1)+fb(n-2)
}
console.log(fb(4)) //3
var objCopy = function (obj) {
if (typeof obj !== 'object') return;
// // 根据obj的类型判断是新建一个数组还是对象
var newObj = obj instanceof Array ? [] : {};
for (var key in obj) {
if (obj.hasOwnProperty(key)) {
newObj[key] = typeof obj[key] === 'object' ? objCopy(obj[key]) : obj[key];
}
}
return newObj;
}
var sourObj = {
a: 1,
name: 'hello',
b: 23
}
let targeObj = objCopy(sourObj, {});
targeObj.a = 10;
console.log(sourObj); // {a: 1, name: "hello", b: 23}
console.log(targeObj); // {a: 10, name: "hello", b: 23}