A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

public class Test1_Rabbit {

        /**
         *题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,
         *假如兔子都不死,问每个月的兔子对数为多少?
                程序分析: 兔子的规律为数列1,1,2,3,5,8,13,21....

         */
        public static void main(String[] args) {
                int n = 10;
                System.out.println("第"+n+"个月兔子总数为"+fun(n));
        }
        private static int fun(int n){
                if(n==1 || n==2)
                   return 1;
                else
                   return fun(n-1)+fun(n-2);
        }
}
这道题后面返回的是fun(n-1)+fun(n-2),看得不是很懂,请帮忙解析一下。谢谢。

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马