有一对兔子,从出生后第三个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问第二十个月的兔子对数为多少?
首先科普一下“ 斐波那契数列 ”:
“斐波那契数列”和分数的发明者,是意大利数学家列昂纳多·斐波那契。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*)
回归算法题,寻找规律最重要:
第几个月 | 有几对兔子 | 如果计算 |
1 | 1 | 第三个月才开始生 |
2 | 1 | 第三个月才开始生 |
3 | 2 | 老兔子生了一对 |
4 | 3 | 老兔子每月生一对 |
5 | 5 | 老兔子和第三个月生出来的兔子个生一对 |
从表可以看出,从第三个月起,每个月的兔子对数是前两个月之和,那不就完事了吗,规律就出来了,比如我们的规律是:
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 + "对兔子");
}