写一个函数,输入 n ,求斐波那契(Fibonacci)数列的第 n 项。斐波那契数列的定义如下:
F(0) = 0, F(1) = 1
F(N) = F(N - 1) + F(N - 2), 其中 N > 1.
斐波那契数列由 0 和 1 开始,之后的斐波那契数就是由之前的两数相加而得出。
来源:力扣(LeetCode)
题解:递归会超时,因此采用DP。
//递归:
class Solution {
public:
int fib(int n) {
if(n==0)return 0;
if(n==1)return 1;
return fib(n-1)+fib(n-2);
}
};
动态规划:
class Solution {
public:
int fib(int n) {
if(n==0)return 0;
if(n==1)return 1;
int dp[n+1];
dp[0]=0;
dp[1]=1;
for(int i =2;i<n+1;i++){
dp[i]=(dp[i-1]+dp[i-2])%1000000007;//大数取余防止溢出
}
return dp[n];
}
};
青蛙跳台阶同理 写出fn关系即可。