php实现斐波那契数列

数列从第三项开始,每一项都等于前两项之和。

F0=0,F1=1,Fn=F(n-1)+F(n-2)

       递归版和非递归版。

  1. <?php  
  2. function fib($n){  
  3.     $array = array();  
  4.     $array[0] = 1;  
  5.     $array[1] = 1;  
  6.     for($i=2;$i<$n;$i++){  
  7.         $array[$i] = $array[$i-1]+$array[$i-2];  
  8.     }  
  9.     print_r($array);  
  10. }  
  11. fib(10);  
  12. echo "\n------------------\n";  
  13. function fib_recursive($n){  
  14.     if($n==1||$n==2){return 1;}  
  15.     else{  
  16.         return fib_recursive($n-1)+fib_recursive($n-2);  
  17.     }  
  18. }  
  19. echo fib_recursive(10);  
  20. ?>  

 作为C和java的程序猿,在第一次在写非递归的时候,忘记了变量前加$,悲催。

输出结果

  1. Array  
  2. (  
  3.     [0] => 1  
  4.     [1] => 1  
  5.     [2] => 2  
  6.     [3] => 3  
  7.     [4] => 5  
  8.     [5] => 8  
  9.     [6] => 13  
  10.     [7] => 21  
  11.     [8] => 34  
  12.     [9] => 55  
  13. )  
  14.   
  15. ------------------  
  16. 55 

转载于:https://www.cnblogs.com/hehe520/p/6147509.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值