时间:2021-05-20
问题:
一只刚出生的小牛,4年后生一只小牛,以后每年生一只。现有一只刚出生的小牛,问20年后共有牛多少只?
思路:
这种子生孙,孙生子,子子孙孙的问题,循环里面还有循环的嵌套循环,一看就知道是第归问题。
于是乎,第一个版本出现:
可是这种循环在循环的做法可要把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
以上就是本文的全部内容,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了C#算法之关于大牛生小牛的问题。分享给大家供大家参考。具体分析如下:问题:一只刚出生的小牛,4年后生一只小牛,以后每年生一只。现有一只刚出生的小牛
本文较为详细的讲解了C#百万数据查询出现超时问题的解决方法,分享给大家供大家参考之用。具体方法如下:很多时候我们用C#从百万数据中筛选一些信息时,经常会出现程序
c盘空间不足怎么办c盘满了的解决方法c盘空间不足怎么办c盘满了的解决方法c盘空间不足怎么办c盘满了的解决方法c盘空间不足怎么办c盘满了的解决方法c盘空间不足怎么
c盘空间不足怎么办c盘满了的解决方法c盘空间不足怎么办c盘满了的解决方法c盘空间不足怎么办c盘满了的解决方法c盘空间不足怎么办c盘满了的解决方法c盘空间不足怎么
本文实例讲述了PHP实现的回溯算法。分享给大家供大家参考,具体如下:问题:一头大牛驼2袋大米,一头中牛驼一袋大米,两头小牛驼一袋大米,请问100袋大米需要多少头