斐波拉契數列(Fibonacci) 的python實現方式


第一種:利用for循環

利用for循環時,不涉及到函數,但是這種方法對我種小小白來說比較好理解,一涉及到函數就比較抽象了。。。

1 >>> fibs = [0,1]
2 >>> for i in range(8):
3         fibs.append(fibs[-2] + fibs[-1])
4 
5 >>> fibs
6 [0, 1, 1, 2, 3, 5, 8, 13, 21, 34]

 

或者說輸入一個動態的長度:

1fibs = [0,1]
2num  = input('How many Fibonacci numbers do you want?')
3 for i in range(num-2):
4     fibs.append(fibs[-2] + fibs[-1])
5     print (fibs)

 

第二種:利用函數

  函數1:

1 >>> def fibs(num):
2     result = [0,1]
3     for i in range(num-2):
4         result.append(result[-2] + result[-1])
5     return result
6 
7 >>> fibs(10)
8 [0, 1, 1, 2, 3, 5, 8, 13, 21, 34]

   函數2:

1 def fibs(n):
2     a,b = 0,1
3     while a < n:
4         print (a)
5         a,b = b,a+b

 或者是下面這種形式:

def fibs(max):
    n,a,b = 0,0,1
    while n < max:
        print (a)
        a,b = b,a+b
        n = n + 1
    return 'done'

 

增加一個max,就可以使相加的次數與傳入的參數max相一致,比如輸入10,a+b就會相加10次,然后結束循環。如果不用max的形式,只有一個while a < n ,那么到a < n 的時候就會結束循環,因為a不斷的在變成b,所以肯定不是每次有增加1,。 

  函數3:

1 def fibs(n):
2     a,b = 0,1
3     result = []
4     while a < n :
5         result.append(b)
6         a,b = b,a + b
7     return result

 

函數2和函數3差不多,函數2是每增加一個數就打印出來了,函數3是每增加一個數就加到result里面,最后輸出result。

  函數4:利用遞歸 

1 def fab(n):
2   if n==1:
3     return 1
4   if n==0:
5     return 0
6   else:
7     result=int(fab(n-1))+int(fab(n-2))    
8     return result

精簡代碼后如下:

1 def fibs(n):
2     if n == 0 or n == 1:
3         return 1
4     else :
5         return fibs(n-1) + fibs(n-2)

 頭一次領略到python代碼的簡略。。  但是我對遞歸還有有點暈暈的。。。。。

 

測試代碼如下:

1 for i in range(10):
2   print fibs(i)
  

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM