博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JAVA编程题-用java解决兔子问题
阅读量:6435 次
发布时间:2019-06-23

本文共 1274 字,大约阅读时间需要 4 分钟。

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

解答:

分析:从第一对兔子开始,第1个月1对兔子,由于“长到第三个月后每个月又生一对兔子”,所以第2个月也是1对兔子,第3个月时可以生一对兔子,所以总数为2对,这时,其中有一对是以后每个月都可以生一对兔子的老兔子,另一对是一对新兔子,它只有在第三个月的时候才可以每个月生一对兔子;这样的话,第4个月的兔子总数为3对,…以此类推,从第1个月到第12个月的兔子对总数分别为:1,1,2,3,5,8,13,21,34,55,89,144。。。。。

这是一个典型的斐波那契数列。

由于每对新兔子隔一个月才可以生新一对兔子, 每月的兔子对总数为前两个月的兔子对数之和。

(方法一)利用java编程基本实现,程序设计如下:

在这里插入图片描述

代码实现如下:

public class RabbitDemo {

public static void main(String[] args) {

int amount; //每个月的兔子总数

int nAmount = 1; //第一个月的兔子数量

int oAmount = 1; //第二个月的兔子数量

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

amount=1;

System.out.println(“第” + i + “个月的兔子总是为:” + amount);

}

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

amount = oAmount + nAmount;

oAmount = nAmount;

nAmount = amount;

System.out.println(“第” + i + “个月的兔子总是为:” + amount);

}

}

}

(方法二)利用递归的方法来解决斐波那契数列:

在这里插入图片描述

代码实现如下:

import java.util.Scanner;

public class RabbitDemo {

public static void main(String[] args) {

System.out.println(“输入月份”);

Scanner s = new Scanner(System.in);

int month = s.nextInt();

System.out.println(“第” + month + “个月的兔子总是为”+getNum(month));

}

public static int getNum(int month){

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

return 1;

}else{

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

}

}

}

文章来源:搜索引擎大全http://www.iis7.com/b/ssyqdq/

转载于:https://www.cnblogs.com/ngnntds03/p/10766646.html

你可能感兴趣的文章
hive中UDF、UDAF和UDTF使用
查看>>
Hibernate学习(六) HQL
查看>>
linux中权限对文件和目录的意义
查看>>
k8s监控
查看>>
案例5:使用Cookie对象保存页面信息
查看>>
Scala 深入浅出实战经典 第77讲:模式匹配下的提取器动手构造实战
查看>>
我的友情链接
查看>>
Windows Server 2016 和Windows 10的中Hyper-V虚拟机生产检查点
查看>>
版本号呀。乱七八遭的
查看>>
搭建自己的CA服务 - OpenSSL CA 实战
查看>>
webservice客户端专题文档
查看>>
DNS 原理
查看>>
我的友情链接
查看>>
python 列表函数
查看>>
【转载】Myeclipse10 安装Aptana插件
查看>>
Social empire here to create a Facebook new headquarters the big Jiedi - Sohu IT
查看>>
对Java多线程技术中所有方法的详细解析
查看>>
我的友情链接
查看>>
我的友情链接
查看>>
Leetcode#155Min Stack
查看>>