亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

關于“斐波那契數列”的編程

發布時間:2020-05-25 11:57:08 來源:網絡 閱讀:365 作者:kenage 欄目:web開發

關于“斐波那契數列”的編程

       今天上網看到一個有關“斐波那契數列”的數學概念。自己學習編程時間也不短了,就借這個東東練習一下。

       斐波那契數列,又稱黃金分割數列,指的是這樣一個數列:1123581321……在數學上,斐波納契數列以如下被以遞歸的方法定義:F0=0F1=1Fn=F(n-1)+F(n-2)n>=2nN*)(來自百度)

       一開始,我編程的代碼如下:

function fbnq($num) {

     if ($num == 0) {

         return 0;

     }elseif ($num== 1) {

         return 1;

     }else {

         return fbnq($num-2) + fbnq($num-1);

     }

}

$total = 10;

$arr = array();

for ($i=0;$i <$total ;$i++) {

     $arr[$i] = fbnq($i);

     echo  $i. '--->' $arr[$i] . '<br>';

}

 

編好以后,我想OK了,結果把$tatal改到25以后就發現運行越來越慢了。運行到30秒程序就提示運行時間太長了。可能是函數設計的效率問題。因為一開始我考慮用遞歸,n大于3以后,每個數都要通過遞歸來獲得。越往后,遞歸次數越多。實際上,根本不需要用到遞歸。只需要取前面已經做好的運算結果相加就好了。于是,改為以下代碼,$tata改為100也沒問題了:

function fbnq($num) {

     global $arr;

     if ($num == 0) {

         return 0;

     }elseif ($num== 1) {

         return 1;

     }else {

         return $arr[$num-2]  + $arr[$num-1];

     }

}

$total = 100;

$arr = array();

for ($i=0;$i <$total ;$i++) {

     $arr[$i] = fbnq($i);

     echo  $i. '--->' $arr[$i] . '<br>';

}


向AI問一下細節

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

AI

苗栗市| 武胜县| 呈贡县| 阿合奇县| 三原县| 汝南县| 东阳市| 灵寿县| 安岳县| 抚远县| 聂荣县| 青阳县| 金阳县| 汽车| 彭泽县| 社旗县| 南江县| 临泽县| 长顺县| 鹰潭市| 贵定县| 焉耆| 通许县| 砀山县| 衢州市| 阜阳市| 如皋市| 永兴县| 桐梓县| 道孚县| 岑溪市| 阿拉善盟| 怀来县| 元朗区| 信宜市| 满洲里市| 景洪市| 新沂市| 仁布县| 平舆县| 中卫市|