首頁 >後端開發 >php教程 >php實作斐波那契數列方法

php實作斐波那契數列方法

小云云
小云云原創
2017-12-13 10:07:355800瀏覽

本文主要介紹了php實作斐波那契數列程式碼分享,具有一定借鏡價值,需要的朋友可以參考下,希望能幫助大家。

斐波那契數列指的是這樣一個數列1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233,377,610,987,1597 ,2584,4181,6765,10946,17711,28657,46368........

這個數列從第3項開始,每一項都等於前兩項之和。

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

遞歸版和非遞歸版。


<?php 
function fib($n){ 
  $array = array(); 
  $array[0] = 1; 
  $array[1] = 1; 
  for($i=2;$i<$n;$i++){ 
    $array[$i] = $array[$i-1]+$array[$i-2]; 
  } 
  print_r($array); 
} 
fib(10); 
echo "\n------------------\n"; 
function fib_recursive($n){ 
  if($n==1||$n==2){return 1;} 
  else{ 
    return fib_recursive($n-1)+fib_recursive($n-2); 
  } 
} 
echo fib_recursive(10); 
?>


作為C和java的程式猿,第一次在寫非遞歸的時候,忘了變數前加$ ,悲催。

輸出結果


Array 
( 
  [0] => 1 
  [1] => 1 
  [2] => 2 
  [3] => 3 
  [4] => 5 
  [5] => 8 
  [6] => 13 
  [7] => 21 
  [8] => 34 
  [9] => 55 
) 
------------------ 
55


#打擊學會了嗎?趕快動手嘗試。

相關推薦:

詳解python輸出斐波那契數列

js實作斐波那契數列

遞迴與遞推實作斐波那契數列演算法

以上是php實作斐波那契數列方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn