经典小鸡算法

小鸡问题是经典的基础算法问题,今天我们使用php解释并优化小鸡算法问题。

 

1、问题描述

 

公鸡5文钱一只,母鸡3文钱一只,小鸡3只一文钱,用100文钱买一百只鸡,其中公鸡,母鸡,小鸡都必须要有,问公鸡,母鸡,小鸡要买多少只刚好凑足100文钱。

 

 

 

2、算法分析

 

 

 

这是这个问题最常规的解法,看下程序的运行结果。

 

母鸡共4公鸡共18小鸡共78
母鸡共8公鸡共11小鸡共81
母鸡共12公鸡共4小鸡共84
共耗时0.36380910873413

 

这个算法是可以得到问题的答案,但是算法的时间复杂度为O(N3),我们可以尝试优化该算法使其时间复杂度降到O(N)。

 

 

 

3、算法优化

 

 

首先根据问题分析了母鸡、公鸡的取值范围,再通过代数式运算得到小鸡的取值范围,这样通过人为分析缩小参数范围,直接就减少了很多不必要的运算从而提高了算法效率。

 

母鸡共4公鸡共18小鸡共78
母鸡共8公鸡共11小鸡共81
母鸡共12公鸡共4小鸡共84
共耗时0.00051999092102051

运行速度提高了将近1000倍。

 

再来看第二个优化。

 

设母鸡有x,公鸡有y,小鸡有z,则 5x+3y+z/3=100 和 x+y+z=100;

消元得到 15x+9y+z=300 => 14x+8y=200 => y = 25-(7/4)x 

令x=4k 则 y=25-7k, 4k+25-7k+z=100  => 25-3k+z=100 => z=75+3k

由以上可知 k取值区间为 [1,2,3]

 

这个优化也是首先通过数学方程消元来得到各个变量的一元一次方程,再结合已知条件确定参数的范围,这个优化后的算法时间复杂度降为O(N)。

程序运行结果为:

 

母鸡共4公鸡共18小鸡共78
母鸡共8公鸡共11小鸡共81
母鸡共12公鸡共4小鸡共84
共耗时1.978874206543E-5

 

其中1.978874206543E-5 = 0.0000197887

相对上一步优化速度提升了20多倍。

感受到数学的魅力了吧,所以说数学才是算法的基础呢。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值