題目:寫一個函數,輸入n,求斐波那契(Fibonacci)數列的第n項。 |
斐波那契(Fibonacci)數列定義如下:

效率很低的解法:
long long Fibonacci_Solution1(unsigned int n)
{
if(n <= 0)
return 0;
if(n == 1)
return 1;
return Fibonacci_Solution1(n - 1) + Fibonacci_Solution1(n - 2);
}
改進的算法:從下往上計算。首先根據f(0)和f(1)算出f(2),再根據f(1)和f(2)算出f(3)。。。。。依此類推就可以算出第n項了。很容易理解,這種思路的時間復雜度是o(n)。實現代碼如下:
long long Fibonacci(unsigned n)
{
int result[2] = {0 , 1};
if(n < 2)
return result[n];
long long fibMinusOne = 1;
long long fibMinusTwo = 0;
for(unsigned int i = 2 ; i <= n ; ++i)
{
fibN = fibMinusOne + fibMinusTwo;
fibMinusTwo = fibMinusOne;
fibMinusOne = fibN;
}
return fibN;
}
題目:一只青蛙一次可以跳上1級台階,也可以跳上2級。求該青蛙跳上一個n級的台階總共有多少種跳法。 |
可以把n級台階時的跳法看成是n的函數,記為f(n)。當n>2時,第一次跳的時候就有兩種不同的選擇:一是第一次只跳1級,此時跳法數目等於后面剩下的n-1級台階的跳法數目,即為f(n-1);另一種選擇是第一次跳2級,此時跳法數目等於后面剩下n-2級台階的跳法數目,即為f(n-2)。因此,n級台階的不同跳法的總數f(n)=f(n-1)+f(n-2)。分析到這里,不難看出這實際上就是斐波那契數列了。
#include<iostream>
using namespace std;
long Fibonacci_Solution1(unsigned int n)
{
if(n <= 0)
return 0;
if(n == 1)
return 1;
return Fibonacci_Solution1(n - 1) + Fibonacci_Solution1(n - 2);
}
int main()
{
int n;
cin>>n;
cout<<Fibonacci_Solution1(n)<<endl;
return 0;
}
在青蛙跳台階的問題中,如果把條件改成:一只青蛙一次可以跳上1級台階,也可以跳上2級。。。。。它也可以跳上n級,此時該青蛙跳上一個n級的台階總共有多少種跳法?
用數學歸納法可以證明f(n)=2n-1.
