java 例子一对小兔子_java编程经典案例之基于斐波那契数列解决兔子问题实例

本文实例讲述了java基于斐波那契数列解决兔子问题。分享给大家供大家参考,具体如下:

题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?

package com.java.recursion;

/**

* @描述 三种方法实现斐波那契数列

* @项目名称 Java_DataStruct

* @包名 com.java.recursion

* @类名 Fibonacci

* @author chenlin

*/

public class Fibonacci {

/**

* 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,

* 问每个月的兔子总数为多少?

* month 1 2 3 4 5 6

* borth 0 0 1 1 2 3

* total 1 1 2 3 5 8

*/

/**

* 叠加法

*

* @param month

* @return

*/

public static int getTotalByAdd(int month) {

int last = 1;//上个月的兔子的对数

int current = 1;//当月的兔子的对数

int total = 1;

for (int i = 3; i <= month; i++) {

//总数= 上次+当前

total = last + current;

last= current ;

current = total;

}

return total;

}

/**

* 使用数组

*

* @param month

* @return

*/

public static int getTotalByArray(int month) {

int arr[] = new int[month];

arr[1] = arr[2] = 1;

for (int i = 2; i < month; i++) {

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

}

return arr[month - 1] + arr[month - 2];

}

public static int getTotalByRecusion(int month) {

if (month == 1 || month == 2) {

return 1;

} else {

return getTotalByRecusion(month - 1) + getTotalByRecusion(month - 2);

}

}

public static void main(String[] args) {

System.out.println("脚本之家测试结果:");

System.out.println(getTotalByAdd(3));

System.out.println(getTotalByAdd(4));

System.out.println(getTotalByAdd(5));

System.out.println(getTotalByAdd(6));

}

}

运行结果:

希望本文所述对大家java程序设计有所帮助。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值