Java问题抽象和递归(母羊生母羊问题为例)

问题:

  一头母羊的寿命是5年,它会在第2年底和第4年底各生下一头母羊,第5年底死去,问一开始农场有1头母羊,N年后,农场会有多少只母羊?

解析1)

  这道题不用刻意的去注意它的逻辑,也不用伤脑筋的去挖掘它暗藏着什么公式,只要按人的正常生活和自然规律理解一下就行了。
  首先虚拟一只母羊,这只母羊只有一个属性,就是年龄:

class Sheep {
    public int age = 0; // 默认一只新羊的年龄为0
}

  然后这个人有一个计数器,来计算N年后牧场羊的个数。这个计数器的工作原理是:以年为单位开始计算,每经过一年,循环牧场所有的羊:
  (1)使羊的年龄加1,
  (2)如果母羊今天2岁了或是4岁了,就让它生一只小羊,
  (3)如果母羊今年5岁了,就让他过世,并清理牧场

复制代码
    // n为过的年数
    public static int getSheeps(int n) {
        // sheeps表示整个羊的生态圈
        ArrayList<Sheep> sheeps = new ArrayList<Sheep>();
        sheeps.add(new Sheep());
        
        List<Sheep> addSheeps = new ArrayList<Sheep>();//待添加到生态圈的新羊
        List<Sheep> delSheeps = new ArrayList<Sheep>();//待从生态圈删除的羊

        for (int i = 1; i <= n; i++) {
            for (Sheep s : sheeps) {
                s.age++;
                if (s.age==2||s.age==4) {// 羊仍存活
                    addSheeps.add(new Sheep());
                } else if(s.age==5){ // 羊死亡,加入删除列表delSheeps中,等待删除
                    delSheeps.add(s);
                }
            }

            sheeps.addAll(addSheeps);
            sheeps.removeAll(delSheeps);
            addSheeps.clear();//清空addSheeps
            delSheeps.clear();//清空待删除列表中的元素
        }

         return sheeps.size(); // 最后总羊数即羊生态圈中的羊数目
    }
复制代码

解析2)

  凡是碰到“一生二、二生三、三生万物”的问题,无疑用递归算法(顺便和斐波那契数列联系起来)。下面是一个完整的代码:

复制代码
public class MyMain{

    public static int get(int year)
    {
        int num=1;    //The initial sheep number

        for(int i=1; i<=year; i++){
            if(i==2){
                num+=get(year-2);
            }else if(i==4){
                num+=get(year-4);
            }else if(i==5){
                num--;    
            }
        }
        
        return num;
    }
    
    public static void main(String[] args) {
        String line1="";
        String line2="";
        for(int i=1;i<=18;i++){
            line1+="第"+i+"年"+"    ";
            line2+=get(i)+"    ";
        }
        System.out.println(line1);
        System.out.println(line2);
    }
}
复制代码


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值