问题:
一只刚出生的小牛,4年后生一只小牛,以后每年生一只。现有一只刚出生的小牛,问20年后共有牛多少只?
思路:
这种子生孙,孙生子,子子孙孙的问题,循环里面还有循环的嵌套循环,一看就知道是第归问题。
于是乎,第一个版本出现:
public long Compute1(uint years) { //初始化为1头牛 long count = 1; if (years <= 3) { return count; } int i = 4; while (i <= years) { int subYears = i - 3; count += Compute1((uint)(subYears)); i++; } return (long)count; }
可是这种循环在循环的做法可要把cpu老兄累坏了,你不信输入一个100年测试一下上面的方法,我等了半天,都没结果,改进一下吧,老牛(牛魔王)和小牛(红孩儿,奶奶的串种了),具有相同的生育能力,他们的生育曲线是一样的,所以小牛可以复用老牛的生育经验亚,这样就解决了重复计算一只牛第n年的时候一共生多少只的问题了,当年龄比较大的时候,明显大大降低cpu的运算次数,下面是基于这种思路的算法
Hashtable table = new Hashtable(); public long Compute(uint years) { //初始化为1头牛 long count = 1; if (years <= 3) { return count; } int i = 4; while (i <= years) { int subYears = i - 3; if (table.ContainsKey(subYears)) { count = (long)table[subYears]; } else { count += Compute((uint)(subYears)); } if (!table.ContainsKey(subYears)) { table.Add(subYears, count); } i++; } return (long)count; }
用测试程序测试一下上面的推论吧,结果如下:
1)当输入years比较小的时候,第一种方法耗时短,但两者的时间基本在一个数量级上
2)当输入years比较大的时候,比如40以上的,第二种算法比第一种性能比在100以上,而且输入years越高,性能比越悬殊。
测试结果截图:
20年
50年
源程序以及测试程序:http://xiazai.jb51.net/201606/yuanma/HowMoneyCows(jb51.net).rar
以上就是本文的全部内容,希望能给大家一个参考,也希望大家多多支持小牛知识库。
本文向大家介绍解决@Around对静态方法不生效的问题,包括了解决@Around对静态方法不生效的问题的使用技巧和注意事项,需要的朋友参考一下 场景: 在处理定时任务时,由于这几个方法都是静态方法,在aop的切面中使用@Around注解,进行监控方法调用是否有异常。 发现aop没有生效。 代码如下: 产生原因: 可能是由于静态方法是属于类的,而非静态方法是属于Bean的,该类会被加载到容器中。具体
本文向大家介绍iOS 解决UICollectionView 计算 Cell 大小的问题,包括了iOS 解决UICollectionView 计算 Cell 大小的问题的使用技巧和注意事项,需要的朋友参考一下 前言 API 不熟悉导致的问题,想当然的去理解果然会出问题,这里记录一下 UICollectionView 使用问题。 正文 陷阱一:minimumLineSpacing、minimu
$$f(x_0+\delta x) = f(x_0) + f{'}(x_0)\delta_x + \frac {f{''}(x_0)} {2}\delta_x2 + o(\delta2_x)= g(\delta_x) +o(\delta_x^2)$$ 关于$$\delta_x$$的二次函数$$g(\delta_x)$$的极值点为$$-\frac {f{'}(x_0)} {f{''}(x_0)}$$
本文向大家介绍微信小程序new Date()方法失效问题解决方法,包括了微信小程序new Date()方法失效问题解决方法的使用技巧和注意事项,需要的朋友参考一下 iOS系统对js中的new Date()方法有格式要求 正确写法应该是 而实际应该过程中日期格式大部分都是2019-07-24这种,所以在实际应用过程中需要用正则对字符串进行预处理 在小程序开发过程中用到一个日期转换方法,然而苹果手机就
设f(x)是二次可微实函数,又设$x^{(k)}$是f(x)一个极小点的估计,我们把f(x)在$x^{(k)}$处展开成Taylor级数, 并取二阶近似。 上式中最后一项的中间部分表示f(x)在$x^{(k)}$处的Hesse矩阵。对上式求导并令其等于0,可以的到下式: 设Hesse矩阵可逆,由上式可以得到牛顿法的迭代公式如下 (1.1) 值得注意 , 当初始点远离极小点时,牛顿法
本文向大家介绍JS小数运算出现多为小数问题的解决方法,包括了JS小数运算出现多为小数问题的解决方法的使用技巧和注意事项,需要的朋友参考一下 写在前面的话: 今天帮同事解决了一个问题,就是小数相乘出现很多位小数的问题;这个问题自己以前也遇到过,现在特意来总结一下; Number类型: Number类型是ECMAScript中最常用和最令人关注的类型了;这种类型使用IEEE754格式来表示整数和浮点数