黑马程序员技术交流社区

标题: 初见递归 0.0 [打印本页]

作者: 黑马-陈思源    时间: 2013-3-28 02:48
标题: 初见递归 0.0
本帖最后由 黑马-陈思源 于 2013-3-28 15:42 编辑

static int b(int m){
            if(1>m){
                return 0;
            }else{
                return m---b(m);
            }
        }        
   
  public static void main(String[] args) {
    int t=b(10);

    System.out.println(t);
}
为什么输出的t=5???求原因????
作者: 李尧    时间: 2013-3-28 03:16
本帖最后由 李尧 于 2013-3-28 03:39 编辑

10>1所以执行else,请从从上往下看等号左边部分,再从下往上看等号右边部分.....
9-b(9)=9-4=5  <==最终return的结果就是5...所以b(10)=5
        |else
        8-b(8)=8-4=4
                |else
                7-b(7)=7-3=4
                        |else
                        6-b(6)=6-3=3
                                |else
                                5-b(5)=5-2=3
                                        |else
                                        4-b(4)=4-2=2
                                                |else
                                                3-b(3)=3-1=2
                                                        |else
                                                        2-b(2)=2-1=1    不写了,依次类推,这就是递归....
                                                                |else
                                                                1-b(1)=1-0=1  return 1 给b(2)
                                                                        |else
                                                                         0-b(0)=0  return 1 给b(1)
                                                                                 |
                                                                               0<1   return 0 给b(0)
卤煮,乃一定要看懂吖!!我写崩溃了我....挣个技术分我容易么....{:soso_e105:}
作者: 丘凤光    时间: 2013-3-28 08:21
楼上的写了这么一大串,太给力了
作者: fighting    时间: 2013-3-28 09:39
初看这个式子还真是有点莫名其妙: m---b(m);
三个减号。。。是这样执行的吧 (m--) - b(m)

式子的执行结果是这样的:10-(9-(8-(7-(6-(5-(4-(3-(2-(1)))))))))
这是两个等差数列么!?




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2