教程集 www.jiaochengji.com
教程集 >  脚本编程  >  php  >  正文 PHP 斐波那契数列的实现代码

PHP 斐波那契数列的实现代码

发布时间:2017-07-16   编辑:jiaochengji.com
分享一例php实现斐波那契数列的代码,即黄金分割数列,有需要的朋友参考下吧。

本节内容:
斐波那契数列(Fibonacci Sequence),又称黄金分割数列,如何用php来实现?

前言:    
斐波那契数列(Fibonacci Sequence),又称黄金分割数列,指的是这样一个数列:1、1、2、3、5、8、13、21、……
在数学上,斐波纳契数列以如下被以递归的方法定义:F0=0,F1=1,Fn=F(n-1)+F(n-2)(n>=2,n∈N*)。

本文用递归和迭代两种方法实现斐波那契数列。

例1,斐波那契数列的实现代码。
 

复制代码 代码示例:
<?php 
/**
* 斐波那契数列
* by www.jbxue.com
*/
class Fibonacci 

    /**
     * 迭代方法获取fibonacci第n项数值
     *
     * @param int $n            
     * @return int
     */ 
    public static function fib_interation ($n) 
    { 
        $fib = array(); // 定义fibonacci数组 
         
        if ($n < 0) { 
            return 0; 
        } 
         
        for ($fib[0] = 0, $fib[1] = 1, $i = 2; $i <= $n; $i ++) { 
            $fib[$i] = $fib[$i - 1] + $fib[$i - 2]; 
        } 
         
        return $fib[$n]; 
    } 
 
    /**
     * Description:递归方法获取fibonacci第n项数值
     *
     * @param int $n            
     * @return int
     */ 
    public static function fib_recursive ($n) 
    { 
        if ($n <= 0) { 
            return 0; 
        } elseif ($n == 1) { 
            return 1; 
        } else { 
            return self::fib_recursive($n - 1) + self::fib_recursive($n - 2); 
        } 
    } 

 
$fib1 = Fibonacci::fib_interation(5); 
echo $fib1 . "\n"; 
 
$fib2 = Fibonacci::fib_recursive(10); 
echo $fib2 . "\n"; 
 
?> 

运行结果,如下图:
斐波那契数列

哪位朋友有更好的方法,也欢迎分享交流下,以期实现更完美的斐波那契数列算法。

您可能感兴趣的文章:
PHP 斐波那契数列的实现代码
PHP迭代器实例 php实现斐波纳契数列函数
如何用PHP迭代器来实现一个斐波纳契数列
Python斐波那契数列是什么?怎么用?
提速 72 倍,在 Python 里面调用 Golang 函数
如何理解python中的迭代
python动态规划算法是什么?
一文了解Python中的递归
【Golang 基础】 Go 语言 函数式编程
Python中常用的查找数据结构及算法汇总

[关闭]
~ ~