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

/**
* 使用递推的方式处理斐波那契数列
* @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 findValue(int i) {
  if(i==1||i==2)
   return 1;
  else{
   return findValue(i-1)+findValue(i-2);
  }
 }
 


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

posted on 2014-12-23 19:30  @ 小浩  阅读(342)  评论(0编辑  收藏  举报