您的位置:首页 > 其它

农场有头大母牛,每年生头小母牛,小母牛五年后生小母牛,问20年后农场一共有多少头牛?(用面向对象的思想)

2013-10-10 09:27 288 查看
笔试题

代码如下:

package cn.edu.test;

import java.util.ArrayList;
import java.util.List;

/**
 * 农场有头大母牛,每年生头小母牛,小母牛五年后生小母牛,问20年后农场一共有多少头牛?(用面向对象的思想)
 * 采用面向对象的思想:农场是一个对象,农场这个对象里存放着母牛,该对象应该提供一个方法用于统计N年后农场的母牛的总数。
 * 母牛也是一个对象,母牛这个对象里有一个年龄属性,该对象有生长的方法以及生育的方法。
 * 
 * @author YCY
 * 
 */
class Cow {
	private int age;

	public Cow(int age) {
		this.age = age;
	}

	public int getAge() {
		return age;
	}

	public void setAge(int age) {
		this.age = age;
	}

	/*
	 * 每年长大一岁
	 */
	public void grow() {
		this.age++;
	}

	/*
	 * 母牛生小牛,如果年龄达到5岁,则可以每年都生一头小母牛,反之,则不能生育,返回null
	 */
	public Cow generation() {
		if (this.age >= 5)
			return new Cow(0);
		return null;
	}
}

class Farm {
	// cows集合存放所有母牛对象
	private List<Cow> cows = new ArrayList<Cow>();

	public List<Cow> getCows() {
		return cows;
	}

	public void setCows(List<Cow> cows) {
		this.cows = cows;
	}

	/*
	 * 第N年后农场的牛的数量
	 */
	public int getCowNum(int year) {
		// children集合存放每年所有母牛生的小母牛对象
		List<Cow> children = new ArrayList<Cow>();
		for (int i = 0; i < year; i++) {
			for (Cow c : cows) {
				c.grow();
				Cow cc = c.generation();
				if (cc != null) {// 如果该母牛可以产仔了,则将其产的小母牛加入children集合中
					children.add(cc);
				}
			}
			cows.addAll(children);// 将整个小母牛集合加入所有母牛的集合中
			children.clear();// 每年过后将children集合清空
		}
		return cows.size();
	}

}

public class MyTest {

	public static void main(String[] args) {
		Farm farm = new Farm();
		// 首先创建一个已经可以产仔的母牛对象
		Cow c = new Cow(5);
		// 将这个母牛添加到农场中
		farm.getCows().add(c);
		int num = farm.getCowNum(20);// 20年后农场的牛的总数
		System.out.println(num);// 结果:431
	}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐