中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP之斐波那契數列的算法有哪些

發布時間:2020-09-08 11:09:42 來源:億速云 閱讀:154 作者:小新 欄目:編程語言

這篇文章主要介紹了PHP之斐波那契數列的算法有哪些,具有一定借鑒價值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。

前言

前段時間,遇到優化計算斐波那契數列的常規遞歸方法,但是一時間并沒有及時想到很好的方法,所以后面查找了相關資料,總結了多種計算解法,所以分享出來,和大家一起交流學習。

斐波那契數是什么

斐波那契數列(Fibonacci sequence),又稱黃金分割數列、因數學家列昂納多·斐波那契(Leonardoda Fibonacci)以兔子繁殖為例子而引入,故又稱為“兔子數列”,指的是這樣一個數列:1、1、2、3、5、8、13、21、34、……在數學上,斐波那契數列以如下被以遞推的方法定義:F(1)=1,F(2)=1, F(n)=F(n - 1)+F(n - 2)(n ≥ 3,n ∈ N*)。

知道了斐波那契數,那么下面我們就用多種不同的方法來計算獲取第N位斐波那契數。

普通遞歸

這種方法是最常規的,直接根據定義F(n)=F(n - 1)+F(n - 2)遞歸計算即可,但是性能是最低的。

/**
 * 普通遞歸
 * @param int $n
 * @return int
 */function fib($n = 1){    // 低位處理
    if ($n < 3) {        return 1;
    }    // 遞歸計算前兩位
    return fib($n - 1) + fib($n - 2);
}

遞歸優化

從上面的遞歸方法可以看到,進行了很多的重復計算,性能極差,如果N越大,計算的次數太可怕了,那么,既然因為重復計算影響了性能,那么優化就從減少重復計算入手,即把之前計算的存儲起來,這樣就避免了過多的重復計算,優化了遞歸算法。

/**
 * 遞歸優化
 * @param int $n
 * @param int $a
 * @param int $b
 * @return int
 */function fib_2($n = 1, $a = 1, $b = 1){    if ($n > 2) {        // 存儲前一位,優化遞歸計算
        return fib_2($n - 1, $a + $b, $a);
    }    return $a;
}

記憶化自底向上

自底向上通過迭代計算斐波那契數的子問題并存儲已計算的值,通過已計算的值進行計算。使用for循環,減少遞歸帶來的重復計算問題。

/**
 * 記憶化自底向上
 * @param int $n
 * @return int
 */function fib_3($n = 1){
    $list = [];    for ($i = 0; $i <= $n; $i++) {        // 從低到高位數,依次存入數組中
        if ($i < 2) {
            $list[] = $i;
        } else {
            $list[] = $list[$i - 1] + $list[$i - 2];
        }
    }    // 返回最后一個數,即第N個數
    return $list[$n];
}

自底向上進行迭代

最低位初始化賦值,使用for從低位到高位迭代計算,從而得到第N個數。

/**
 * 自底向上進行迭代
 * @param int $n
 * @return int
 */function fib_4($n = 1){    // 低位處理
    if ($n <= 0) {        return 0;
    }    if ($n < 3) {        return 1;
    }
    $a = 0;
    $b = 1;    // 循環計算
    for ($i = 2; $i < $n; $i++) {
        $b = $a + $b;
        $a = $b - $a;
    }    return $b;
}

公式法

通過了解斐波那契序列和黃金分割比之間的關系,使用黃金分割率計算第N個斐波那契數。

/**
 * 公式法
 * @param int $n
 * @return int
 */function fib_5($n = 1){    // 黃金分割比
    $radio = (1 + sqrt(5)) / 2;    // 斐波那契序列和黃金分割比之間的關系計算
    $num = intval(round(pow($radio, $n) / sqrt(5)));    return $num;
}

無敵欠揍法

這個方法,我就不多說了吧,大家都懂的,但是千萬別輕易嘗試……

/**
 * 無敵欠揍法
 * @param int $n
 * @return int
 */function fib_6($n = 1){    // 列舉了30個數
    $list = [1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233, 377, 610, 987, 1597, 2584, 4181, 6765, 10946, 17711, 28657, 46368, 75025, 121393, 196418, 317811, 514229, 832040, 1346269];    return $list[$n];
}

感謝你能夠認真閱讀完這篇文章,希望小編分享PHP之斐波那契數列的算法有哪些內容對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,遇到問題就找億速云,詳細的解決方法等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

大田县| 东乡| 台东县| 建昌县| 霞浦县| 凤城市| 本溪市| 平塘县| 昌邑市| 奉贤区| 岚皋县| 许昌市| 横山县| 三明市| 安塞县| 晋中市| 大足县| 青河县| 尉氏县| 南宁市| 舟曲县| 唐山市| 襄汾县| 商都县| 南平市| 赣榆县| 绥宁县| 临清市| 凤台县| 兰溪市| 苏尼特右旗| 湘乡市| 望奎县| 鹤庆县| 江陵县| 大连市| 航空| 化州市| 芜湖县| 苍梧县| 青阳县|