| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 481 人关注过本帖
标题:求分析 不懂!
只看楼主 加入收藏
hongshuai567
Rank: 1
等 级:新手上路
帖 子:18
专家分:0
注 册:2012-5-29
结帖率:50%
收藏
已结贴  问题点数:2 回复次数:2 
求分析 不懂!
古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第四个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?   
  兔子的规律为数列1,1,2,3,5,8,13,21....   
public class exp2{n
    public static void main(String args[]){
        int i=0;
        for(i=1;i<=20;i++)
            System.out.println(f(i));
    }
    public static int f(int x)
    {
        if(x==1 || x==2)
            return 1;
        else
            return f(x-1)+f(x-2);
    }
}
搜索更多相关主题的帖子: 小兔子 public 
2012-09-23 09:10
流星雨
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:JAVA风暴
等 级:版主
威 望:43
帖 子:1854
专家分:1868
注 册:2004-5-30
收藏
得分:2 
你这个问题本来就问的有问题,难怪没人敢回答了,我简单的看了一下,“假如兔子都不死,问每个月的兔子总数为多少?” 按照你这个问题,那就要输出一个死循环了,因为你并没有说截止到那个月  ,但是照程序“for(i=1;i<=20;i++)
”来看,貌似又是统计20个月以你的。简单的给你解释一下吧
public class exp2{n
    public static void main(String args[]){
        int i=0;
        for(i=1;i<=20;i++)//这里应该是按20个月以内来看,每月多少个兔子
            System.out.println(f(i));
    }
    public static int f(int x)//这里用到了递归,主要是因为小兔子也会生兔子
    {
        if(x==1 || x==2) //因为前两个月不会生,所以直接RETURN 1
            return 1;
        else
            return f(x-1)+f(x-2);//递归调用自己,原理如上边一句。这个是统计兔子生的小兔子的
    }
}


感谢你们带我找到星空下美丽神话,无论经历多少苦痛也不放弃的梦;插上希望翅膀乘风我和你们飞翔,飞过海天尽头携手把梦想实现.....
2012-09-28 16:55
流星雨
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:JAVA风暴
等 级:版主
威 望:43
帖 子:1854
专家分:1868
注 册:2004-5-30
收藏
得分:0 
不过貌似觉得你还没入门,这个东西,你自己先去看看递归的概念。什么是递归。以及递归怎么用。

感谢你们带我找到星空下美丽神话,无论经历多少苦痛也不放弃的梦;插上希望翅膀乘风我和你们飞翔,飞过海天尽头携手把梦想实现.....
2012-09-28 16:56
快速回复:求分析 不懂!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.019475 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved