牛年求牛:有一母牛,到4岁可生育,每年一头,所生均是一样的母牛,到15岁绝育,不再能生,20岁......

问题: 

牛年求牛:有一母牛,到4岁可生育,每年一头,所生均是一样的母牛,到15岁绝育,不再能生,20岁死亡,问n年后有多少头牛?

Php代码  收藏代码

方法一是用一个数组做中间联系,每出生一头牛往数组里添加一个元素,以当前的年份为值,最后统计数组元素,得出总数

// 方法1:按照时间推移计算, 嵌套循环  
    function countcows($years) {  
        $cows[] = 0;  
        if($years < 4) return 1;  
        for($i=4; $i <= $years; $i++) {  
            for($j=0, $k=count($cows); $j<$k; $j++) {  
                $age = $i - $cows[$j];  
                if($age >= 4 && $age < 15) $cows[] = $i;  
                else if($age == 20) unset($cows[$j]);  
            }  
        }  
        return count($cows);  
    }

Php代码  收藏代码

这个使用递归,用一个静态变量存值,

// 方法2:不断的计算每头牛的产出, 使用递归  
    function countcows2($years) {  
        static $cows_num = 1;  
        for($i=1; $i<=$years; $i++) {  
            if($i >= 4 && $i < 15) {  
                $cows_num ++;  
                countcows2($years - $i);  
            }  
            if($i == 20) $cows_num --;  
        }  
        return $cows_num;  
    }

Php代码  收藏代码

echo countcows(29);  
    echo '<br/>';  
    echo countcows2(29);

------------

 

转载于:https://my.oschina.net/qingyi0908/blog/77340

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值