php方法递归调用自己,递归调用函数方法

递归调用 (---斐波那契数列)

递归:在一个函数内部再一次调用自己;

效率:在本次调用还未结束时,就开始了下次的调用,本次调用就会被挂起,直到所有的调用都完成之后,才会依次返回。

形如数学函数:f(n)的阶乘

ex: 5!=5*4! (5*4*3*2*1)

4!=4*3! (4*3*2*1)

3!=3*2! (3*2*1)

2!=2*1! (2*1)

1!=1;

F(n)!=n*f(n-1)!

//计算数字n的阶乘 (if方法)

function f(n){

if(n==1){ //边界条件

return 1;

}else{ //没到边界条件

return n*f(n-1);

}

}

/*或者:return n==1 ? 1 : n*f(n-1); (三目运算方法)

function f(n){

var result = return n==1 ? 1 : n*f(n-1);

return result;

}

*/

//计算5的阶乘?

function testF(){

var result = f(5);

console.log(result);

}

testF();

练习:

以下数列: 斐波那契数列

1,1,2,3,5,8,13,21,34,55……….

已知:该数列中的第一个数和第二个数都是1

从第三个数字开始,每个数字都是前两个数之和

问题: 用一个函数,求该数列中第n个数字的值

Document

function f(n){

if(n==1 || n==2){

return 1;

}else{

return f(n-1)+f(n-2);

}

}

function testF(){

var result=f(20);

console.log(result);

}

testF();

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值