斐波那契数列
斐波那契数 (通常用 F(n) 表示)形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始,后面的每一项数字都是前面两项数字的和。也就是:
F(0) = 0,F(1) = 1
F(n) = F(n - 1) + F(n - 2),其中 n > 1
给定 n ,请计算 F(n) 。
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/fibonacci-number
问题描述:
使用递归直接解决:
int fib(int n){
if(n==0) return 0;
else if(n==1) return 1;
else
return fib(n-1)+fib(n-2);
}
原因分析:
提示:这里填写问题的分析:
当n比较大时,Fn也非常大,现在我们想知道,Fn除以10007的余数是多少,这时使用递归会出现超时问题。
解决方案:
提示:这里填写该问题的具体解决方案:
int fib(int n){
if (n <2) return n;
int a=0;int b=1;int x=0;
for(int i=2; i<=n; i++) {
x=(a+b)%1000000007;
a=b;
b=x;
}
return x;
}