一个圣诞老人养了一只驯鹿,三年后,这只驯鹿每一年会生出1只驯鹿,生出来的驯鹿三年后,又可以每年生出一只驯鹿……问圣诞老人10年后有多少只驯鹿?N年呢?(不考虑其...

 
import java.util.ArrayList;

public class DeerProblem {
	//鹿群
	ArrayList<Deer>deers;
	//初始化鹿群,将一只年龄为0的鹿放入鹿群中
	public DeerProblem(){
		deers=new ArrayList<Deer>();
		deers.add(new Deer(0));
	}
	public ArrayList<Deer> getDeers(int year){
		//新的鹿群
		ArrayList<Deer> newDeers;
		for(int i=1;i<=year;i++){
			newDeers=new ArrayList<Deer>();
			for(Deer deer:deers){
				//将旧鹿群中的每只鹿放入新鹿群中
				newDeers.add(deer);
				//遍历每只鹿,年龄+1
				deer.setAge(deer.getAge()+1);
				//大于3岁的鹿,添加一只新的小鹿到新鹿群中
				if(deer.getAge()>3){
					newDeers.add(new Deer(0));
				}
			}
			//新鹿群赋给初始化的旧鹿群,
			deers.clear();
			deers=newDeers;
		}
		return deers;
	}
	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		DeerProblem deerPro=new DeerProblem();
		System.out.println(deerPro.getDeers(10).size());
	}
}
class Deer{
	private int age;
	public Deer(){
		
	}
	public Deer(int age){
		this.age=age;
	}
	public void setAge(int age) {
		this.age = age;
	}
	public int getAge() {
		return age;
	}
}
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值