JavaScript:递归~递归深克隆对象

本文介绍了递归函数在计算阶乘、删除空children数组和深克隆对象中的应用,同时讨论了递归的性能问题以及在前端开发中的使用策略。作者强调了递归的优缺点,并分享了学习前端技术的重要性和资源。

1递归 函数:

通过递归来计算任意数的阶乘

递归的核心思想就是“化整为零”,将一个大问题拆分为一个小问题

例子:想求6的阶乘,如何计算?

720 6! = 6 * 5!

120 5! = 5 * 4!

24 4! = 4 * 3!

6 3! = 3 * 2!

2! = 2 * 1

其实递归的功能和循环类似,都是可以用来反复去执行某段代码的,

但是相比于循环来说,递归的执行性能要低的多,

并且大部分解析器都会限制递归执行的次数

相比于循环,递归的逻辑(代码)更容易理解

一般情况下,开发中递归不是我们的首选,甚至我们应该尽量避免使用递归

// 递归版本的阶乘计算

function jieCheng2(n) {

//判断n是否等于1

// 基线条件,设置递归的终止条件

if(n === 1){

return 1;

}

//如果n大于1,例如n=6

//6! = 6 * 5! n! = n * (n-1)!

//递归条件,规定了如何对问题进行拆分

return n * jieCheng2(n-1);

}

// console.log(jieCheng2(10))

// 创建一个函数,用来求一个数幂运算(使用递归)

// 6^6 = 6 * 6^5

// 6^5 = 6 * 6^4

function pow(num, times) {

//设置基线条件(递归的停止)

if(times === 1){

// 要计算num的1次幂,直接返回num

return num;

}else if(times === 0){

return 1;

}

//设置递归条件(拆分问题)

return num * pow(num, times-1);

}

console.log(pow(2, 10));

2递归删除某个元素:

// 递归 删除空的children数组

const
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值