经典递归函数

阶乘函数

function factorial(num) {
    if(num <= 1) {
        return 1;
    } else {
        return num * factorial(num-1);
    }
}

弊端: 递归函数依赖函数名,如果我按以下方式调用会导致报错。

var demo = factorial;
factorial = null;
demo(4) // error

我们可以使用arguments.callee来内部函数调用,因为arguments.callee是一个指向正在运行函数的指针。但是严格模式下不能通过脚本访问arguments.callee,所以会导致错误。

function factorial(num) {
    if( num<=1 ) {
        return 1;
    } else {
        return num * arguments.callee(num-1);
    }
}

我们可以使用命名函数表达式来解决这个问题。

var factorial = (function f(num) {
    if( num<= 1) {
        return 1;
    } else {
        return num * f(num-1);
    }
})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值