求第n個斐波那契數
阿新 • • 發佈:2021-09-17
斐波那契數,通常用 F(n) 表示,形成的序列稱為 斐波那契數列 。該數列由 0 和 1 開始,後面的每一項數字都是前面兩項數字的和。也就是:
F(0) = 0,F(1) = 1 F(n) = F(n - 1) + F(n - 2),其中 n > 1
給你 n ,請計算 F(n) 。
示例 1:
輸入:2 輸出:1 解釋:F(2) = F(1) + F(0) = 1 + 0 = 1
示例 2:
輸入:3 輸出:2 解釋:F(3) = F(2) + F(1) = 1 + 1 = 2
示例 3:
輸入:4 輸出:3 解釋:F(4) = F(3) + F(2) = 2 + 1 = 3
方法一:
class Solution { public int fib(int n) { if (n <= 1) return n; return fib(n-1) + fib(n-2); } }
方法二:
class Solution { public int fib(int n) { if (n <= 1) return n; int first = 0; int second = 1; for (int i = 0; i < n-1; i++) {int sum = first + second; first = second; second = sum; } return second; } }