当前位置: 首页 > 编程笔记 >

C#算法之大牛生小牛的问题高效解决方法

长孙德惠
2023-03-14
本文向大家介绍C#算法之大牛生小牛的问题高效解决方法,包括了C#算法之大牛生小牛的问题高效解决方法的使用技巧和注意事项,需要的朋友参考一下

问题:
  一只刚出生的小牛,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格式来表示整数和浮点数