理清递归思路(Java)

理清递归思路(Java)

一、例题
package com.lxf.test;


public class MyTest {
    public static void main(String[] args) {
        System.out.println("foo1="+foo1(5));
    }

    /**
     * @param n
     * @return
     */
    static int foo1(int n){
        if(n<2) return n;
        return foo1(n-1)+foo1(n-2);
    }
}

输出:

foo1=5

分析:

 foo(5)
 foo(4) +foo(3)
 foo(3)+foo(2)+foo(2)+foo(1)
 foo(2)+foo(1)+foo(1)+foo(0)+foo(1)+foo(0)+1
 foo(1)+foo(0)+foo(1)+foo(1)+foo(0)+foo(1)+foo(0)+1
 1+0+1+1+0+1+0+1
 5
 //这其实是斐波那契数列算法
二、对比
package com.lxf.test;


public class MyTest {
    public static void main(String[] args) {
        System.out.println("foo1="+foo1(5));
        System.out.println("foo2="+foo2(5));
    }

    /**
     * @param n
     * @return
     * foo(5)
     * foo(4) +foo(3)
     * foo(3)+foo(2)+foo(2)+foo(1)
     * foo(2)+foo(1)+foo(1)+foo(0)+foo(1)+foo(0)+1
     * foo(1)+foo(0)+foo(1)+foo(1)+foo(0)+foo(1)+foo(0)+1
     * 1+0+1+1+0+1+0+1
     */
    static int foo1(int n){
        if(n<2) return n;
        return foo1(n-1)+foo1(n-2);
    }

    /**
     * @param n
     * @return
     * foo(5)
     * 5+4+3+2+1
     */
    static int foo2(int n){
        if(n<2) return 1;
        return n+foo2(n-1);
    }
}

输出:

foo1=5
foo2=15
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值