两位版主,请教一个问题一下,因为对递归调用这块不是怎么熟悉,就这道题而言,如果用递归的方法,怎么能正确返回最后的值啊,意思就是只打印第一天的值,其它天数的不打印出来,我试了几次都木有能正确返回来,请问你们有木有比较好的方法啊?- /*
- 题目:猜一猜猴子摘了多少桃子呢?
- 猴子吃桃的问题:猴子第一天摘下来N个桃子,当天就吃了一半,但是还不过瘾,又多吃了一个,第二天早上又将
- 剩下的桃子吃了一半,又多吃了一个,以后每天早上都吃了前一天剩下的一半零一个,到第十天早上的时候就发现剩下
- 一个桃子了.求第一天一共摘下了多少桃子呢?
- 思路:1、此题是一个数学推理题,可以采用逆向思维进行推理,先定义一个方法用表达式表示出第九天的结果;
- 2、利用递归原理调用计算方法,这样即可得到计算结果。
- 步骤:1、定义一个类,把主函数和计算方法定义在这个类中即可。
- 2、定义计算方法及利用递归原理进行调用计算出结果。
- 3、定义主函数,调用方法即可得到计算结果。
- */
- class Demo
- {
- public static void jiSuan(int i,int j)//定义计算方法
- {
- int sum=j;
- System.out.println("第"+i+"天有"+sum+"个桃子");[color=Red]//这里打印出来的是每天的数值,请问在递归中有什么方法能只打印第一天的数值啊[/color]
- sum=(sum+1)*2;
- i--;
- if(i>0)
- jiSuan(i,sum);//递归调用
- }
- public static void main(String[] args)
- {
- jiSuan(10,1);//调用计算方法
- }
- }
复制代码 |