美文网首页
关于递归的一点想法

关于递归的一点想法

作者: 云上攻城狮 | 来源:发表于2019-10-15 14:19 被阅读0次
关于递归的一点想法

1.优化

如下图所示,递归计算的时候,重复计算了两次 f(5),五次 f(4)。。。。这是非常恐怖的,n 越大,重复计算的就越多,所以我们必须进行优化。

1)如何优化?一般我们可以把我们计算的结果保存起来,例如把 f(4) 的计算结果存起来,当再次要计算 f(4) 的时候,我们先判断一下,之前是否计算过,如果计算过,直接把 f(4) 的结果取出来就可以了,没有计算过的话,再递归计算。

2)用什么保存呢?可以用数组或者 HashMap 保存,我们用数组来保存把,把 n 作为我们的数组下标,f(n) 作为值,例如 arr[n] = f(n)。f(n) 还没有计算过的时候,我们让 arr[n] 等于一个特殊值,例如 arr[n] = -1。当我们要判断的时候,如果 arr[n] = -1,则证明 f(n) 没有计算过,否则, f(n) 就已经计算过了,且 f(n) = arr[n]。直接把值取出来就行了。

也就是说,使用递归的时候,必要

须要考虑有没有重复计算,如果重复计算了,一定要把计算过的状态保存起来,这才能减少计算时间。

2. 层次太多,导致栈空间不够用怎么办

对于递归的问题,我们一般都是从上往下递归的,直到递归到最底,再一层一层着把值返回。

不过,有时候当 n 比较大的时候,例如当 n = 10000 时,那么必须要往下递归10000层直到 n <=1 才将结果慢慢返回,如果n太大的话,可能栈空间会不够用。

对于这种情况,其实我们是可以考虑自底向上的做法的。例如我知道

f(1) = 1;

f(2) = 2;

那么我们就可以推出 f(3) = f(2) + f(1) = 3。从而可以推出f(4),f(5)等直到f(n)。因此,我们可以考虑使用自底向上的方法

相关文章

  • 关于递归的一点想法

    1.优化 如下图所示,递归计算的时候,重复计算了两次 f(5),五次 f(4)。。。。这是非常恐怖的,n 越大,重...

  • 关于递归的一些想法

    树的定义是递归的。 (左子树 根 右子树)。 因为其递归的定义, 所以可以通过递归的思路来访问它的所有节点(访问这...

  • 关于递归的一点理解

    什么是递归,一幅图表示: 拿到这问题第一时间知道这肯定要用递归来解决,但是总觉着无处下手。这个时候我们不妨找一个我...

  • 关于递归的一点感悟

    面试题 然后我们就可以写出我们的递归代码 自己的想法 我们首先根据题意,一步步得出符合题意的公式,最好写出关于n的...

  • 关于递归算法的一点思考

    我们都知道在计算机领域中好的算法代表了:0.省时间1.省空间(RAM,而非Disk) 递归分为两种:线性递归 和 ...

  • go递归

    1.递归的使用 使用递归快速排序 2.关于递归上下文的测试 运行的结果如下:

  • 关于团建的一点想法

    前些日子看到一句话,说“人对了,世界就对了”。乍看稀松平常,细细咀嚼却意味深长。团队建设的目标就是凝聚人心,统一目...

  • 关于事业的一点想法

    01 职场上,人大体上能分成两个类型,一种类型是喜欢与人打交道,跟不同的人交流,遇见不同的事情,比如说做市场、推广...

  • 关于读书的一点想法

    为什么要写这篇文字呢?起因是一个事儿,马上要读初一的小侄子因老师要求要读《西游记》,不得不煎熬着翻开这本书,从上册...

  • 关于婚姻的一点想法

    最近跟几个90初还没结婚的女孩聊天,发现现在女孩子们对于婚姻的观念跟我们80后好不一样。 我自己是个十分传统观念的...

网友评论

      本文标题:关于递归的一点想法

      本文链接:https://www.haomeiwen.com/subject/zilsmctx.html