首页 > 代码库 > 使用递推和递归解决斐波那契数列问题~~~

使用递推和递归解决斐波那契数列问题~~~

/**
* 使用递推的方式处理斐波那契数列
* @param sum
* @param i
* @return
*/
public static int findValue(int n){
if(n==1)
{
return 1;
}
if(n==2)
{
return 2;
}
int sum=1;
int pre=1;
for(int i=3;i<=n;i++)
{
int temp=sum;
sum+=pre;
pre=temp;
}
return sum;
}

/**
* 采用递归的方式处理斐波那契数列
* @param i
* @return
*/
public static int findValue2(int i){
int sum=0;
int pre=1;
if(i==1)
{
return sum;
}
else{
pre=findValue(i--);
sum+=pre;
}
return sum;
}

public static void main(String[] args) {
int value=http://www.mamicode.com/findValue(30);
int value2=findValue2(30);
System.out.println(value);
System.out.println(value2);
}

使用递推和递归解决斐波那契数列问题~~~