递归一:斐波那契数列

/**
 * 题目:斐波那契数列   
 * 描述:大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项。n<=39
 * 解决方案:方法一:递归
 *        方法二:动态规划,如果需要缓存所有的结果,用额外的数组空间进行存储。只要结果的话,就只需要中间的一个变量
 *
 * 裴波那契背景:又称黄金分割数列或者兔子数列,从第三项开始,每一项都等于前两项之和
 *  主要是递归和非递归,
 * */

public class One {
    //递归
    public static int One(int n) {
        if(n ==0 ) {
            return 0;
        }
        if(n == 1  ) {
            return 1;
        }
        return One(n-1)+One(n-2);
    }
    //对结果要求缓存
    public static int Two(int n) {
        if(n<=2) return n;
        int arr[] = new int[n+1];
        arr[0] =0;
        arr[1] =1;
        for(int i=2;i<=n;i++) {
            arr[i] = arr[i-1]  +arr[i-2];
        }
        return arr[n];
    }
    //最优解:
    public static int Three(int n) {
        if(n<2) return n;
        int one = 0;
        int two = 0;
        int result =0;
        for(int i = 2; i<=n;i++) {
            result = one + two;
            one = two;
            two = result;
        }
        return result;
    }
}

 

posted @ 2018-11-16 14:45  弄潮儿儿  阅读(199)  评论(0编辑  收藏  举报