代码:
package com.likou;
import java.util.Arrays;
/**
* 斐波那契数列
* 写一个函数,输入 n ,求斐波那契(Fibonacci)数列的第 n 项。斐波那契数列的定义如下:
*
* F(0) = 0, F(1) = 1
* F(N) = F(N - 1) + F(N - 2), 其中 N > 1.
* 斐波那契数列由 0 和 1 开始,之后的斐波那契数就是由之前的两数相加而得出。
*
* 答案需要取模 1e9+7(1000000007),如计算初始结果为:1000000008,请返回 1。
*
*/
public class test10_1 {
public static void main(String[] args) {
int n = 5;
int re = fun(n);
System.out.println(re);
}
/**
* 使用动态规划来做,最简单,使用递归,会存在很多重复计算
* @param n
* @return
*/
private static int fun(int n) {
int[] dp = new int[n+1];
if (n<0){
return -1;
}
if (n==0){
return 0;
}
if (n==1){
return 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];
}
}