Java算法(二)详细解析:斐波那契数列--兔子繁殖

15 篇文章 0 订阅

有一对兔子,从出生后第三个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问第二十个月的兔子对数为多少?

首先科普一下“ 斐波那契数列 ”:

“斐波那契数列”和分数的发明者,是意大利数学家列昂纳多·斐波那契。1202年,他撰写了《珠算原理》(Liber Abaci)一书。他是第一个研究了印度和阿拉伯数学理论的欧洲人。他的父亲被比萨的一家商业团体聘任为外交领事,派驻地点相当于今日的阿尔及利亚地区,列昂纳多因此得以在一个阿拉伯老师的指导下研究数学。

斐波那契数列:又称黄金分割数列,因数学家列昂纳多·斐波那契以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一个数列:1、1、2、3、5、8、13、21、34、……在数学上,斐波纳契数列以如下被以递归的方法定义:F(0)=1,F(1)=1, F(n)=F(n-1)+F(n-2)(n>=2,n∈N*)

回归算法题,寻找规律最重要:

第几个月有几对兔子如果计算
11第三个月才开始生
21第三个月才开始生
32老兔子生了一对
43老兔子每月生一对
55老兔子和第三个月生出来的兔子个生一对

 

 

 

 

 

 

从表可以看出,从第三个月起,每个月的兔子对数是前两个月之和,那不就完事了吗,规律就出来了,比如我们的规律是:

num [ i ] =num [ i - 2 ] + num [ i - 1 ];

下面我们回归代码,我这边有两种解决方案,第一种是递归,第二种是常规(随便起的哈哈)

递归:

/**
     * 斐波那契数列
     * 生兔子
     * 递归
     *
     * @param month 月数
     */
    public static int rabbit1(int month) {
        if (month < 2) {
            return 1;
        } else {
            return rabbit1(month - 1) + rabbit1(month - 2);
        }
    }



public static void main(String[] args) {

        for(int i =0;i<20;i++){
                System.out.println("第"+(i+1)+"个月有"+rabbit1(i)+"只兔子");
            }

        rabbit2();
    }

常规:

/**
     * 常规方法
     *
     * @return
     */
    public static void rabbit2() {
        int arr[] = new int[20];
        arr[0] = 1;
        arr[1] = 1;
        int sum = 2;
        for (int i = 2; i < arr.length; i++) {
            arr[i] = arr[i - 2] + arr[i - 1];
            System.out.println("第" + (i + 1) + "个月兔子对数为:" + arr[i]);
            sum += arr[i];
        }
        System.out.println("一共有:" + sum + "对兔子");
    }

 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值