今天在一个QQ群中,有人说到这个一个面试题:html
一头母牛在3—10岁的时候每一年能够生一头小牛,生公牛和母牛的比率是50%,在牛12岁的时候就送入屠宰场买了。如今有一个农夫有1头1岁大的母牛,在母牛3岁的时候就送到附近的农场去配种,请问40年后这个农夫可能会有多少头牛,写出相关的代码或答题思路,最好用面向对象。java
polaris将代码(Java实现)写了一下,若有不对的地方欢迎指出。同时也欢迎您给出本身的解法。面试
- package com.polaris.test;
- import java.util.*;
- /**
- * 问题描述:
- *
- * 一头母牛在3—10岁的时候每一年能够生一头小牛,生公牛和母牛的比率是50%,
- * 在牛12岁的时候就送入屠宰场买了。如今有一个农夫有1头1岁大的母牛,
- * 在母牛3岁的时候就送到附近的农场去配种,请问40年后这个农夫可能会有多少头牛,
- * 写出相关的代码或答题思路,最好用面向对象。
- * @author polaris http://www.beijixing001.com
- * @version 1.0
- */
- public class ComputeCattleNum {
- // 保存全部母牛
- private static List<Cattle> cows = new ArrayList<Cattle>();
- // 保存全部当前农夫拥有的牛
- private static List<Cattle> cattles = new ArrayList<Cattle>();
- public static void main(String[] args) {
- // 第一头母牛
- Cattle cow = new Cattle(0,3);
- cows.add(cow);
- // 40年
- for(int i=0;i<40;++i) {
- // 大于等于12岁的牛送到屠宰场卖掉;同时每一年,全部的牛
- for(int j=0;j<cattles.size();++j) {
- Cattle temp = cattles.get(j);
- if(temp.getDead()) {
- cattles.remove(temp);
- }
- // 开始只有一头母猪,年龄不生长
- if(i>0) {
- cattles.get(j).grow();
- }
- }
- // 母牛生小牛
- for(int j=0;j<cows.size();++j) {
- Cattle calf = cows.get(j).bear();
- if(calf!=null) {
- if(calf.getSex()==0)
- cows.add(calf);
- cattles.add(calf);
- }
- }
- }
- System.out.println("40年后农夫拥有" + cattles.size() + "头牛");
- }
- }
- class Cattle {
- // 牛的雌雄:0表明雌,1表明雄
- private int sex;
- // 牛的年龄
- private int age;
- // 是否卖掉(已死)
- private boolean dead = false;
- public Cattle(int sex, int age) {
- this.sex = sex;
- this.age = age;
- }
- /**
- * 生小牛
- * @return 生出的小牛
- */
- public Cattle bear() {
- Cattle calf = null;
- if(this.sex==0) {
- if(this.age>=3 && this.age<=10) {
- calf = new Cattle(random(),0);
- } else {
- //System.out.println("抱歉,此牛过小或太老,不能生育。");
- }
- } else {
- //System.out.println("有没有搞错,公牛也想让它生小牛?");
- }
- return calf;
- }
- private int random() {
- return (int)Math.round(Math.random());
- }
- /**
- * 长大一岁,若是当前大于等于12岁,则卖掉
- */
- public void grow() {
- if(this.age>=12) dead = true;
- else this.age++;
- }
- public int getSex() {
- return this.sex;
- }
- public boolean getDead() {
- return this.dead;
- }
- }