剑指 Offer 10- I. 斐波那契数列文章来源:https://www.toymoban.com/news/detail-694981.html
方法一
class Solution {
int mod = (int) 1e9 + 7;
public int fib(int n) {
if(n <= 1) return n;
int[] dp = new int[n + 1];
dp[1] = 1;
for(int i = 2; i <= n; i++){
dp[i] = (dp[i - 1] + dp[i - 2]) % mod;
}
return dp[n];
}
}
方法二
对方法一进行空间优化。文章来源地址https://www.toymoban.com/news/detail-694981.html
class Solution {
int mod = (int) 1e9 + 7;
public int fib(int n) {
if(n <= 1) return n;
int a = 0, b = 1;
for(int i = 2; i <= n; i++){
int c = (a + b) % mod;
a = b;
b = c;
}
return b;
}
}
到了这里,关于剑指 Offer 10- I. 斐波那契数列的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!