> 作者:დ旧言~
> 座右铭:松树千年终是朽,槿花一日自为荣。> 目标:了解什么是记忆化搜索,并且掌握记忆化搜索算法。
> 毒鸡汤:有些事情,总是不明白,所以我不会坚持。早安!
> 专栏选自:递归、搜索与回溯算法_დ旧言~的博客-CSDN博客
> 望小伙伴们点赞👍收藏✨加关注哟💕💕
一、算法讲解
记忆化搜索(Memoization Search):
是一种通过存储已经遍历过的状态信息,从而避免对同一状态重复遍历的搜索算法。
主要特点和应用场景包括:
- 避免重复计算: 记忆化搜索算法通过缓存已经计算过的结果,以避免对相同输入进行重复计算。这在递归算法中特别有用,因为递归往往会导致相同的子问题被反复解决。
- 提高效率: 通过保存中间计算结果,记忆化搜索算法能够大幅减少算法的时间复杂度,从指数级别降低到多项式级别。
动态规划:
记忆化搜索在动态规划中经常被使用。动态规划是一种解决优化问题的方法,通常包含递归和子问题重叠的特点。记忆化搜索能够避免重复计算,使得动态规划算法更加高效。
递归算法优化:
记忆化搜索主要用于优化递归算法。在递归调用中,如果存在相同的输入参数,记忆化搜索算法将直接返回已经计算过的结果,而不是重新执行计算。
应用于搜索问题:
记忆化搜索不仅用于动态规划,还可以应用于搜索问题,特别是深度优先搜索中的状态记忆。
二、算法习题
2.1 第一题
题目描述:
算法思路:
暴搜:
- 递归含义:给 dfs ⼀个使命,给他⼀个数 n ,返回第 n 个斐波那契数的值;
- 函数体:斐波那契数的递推公式;
- 递归出⼝:当 n == 0 或者 n == 1 时,不⽤套公式。
记忆化搜索:
- 加上⼀个备忘录;
- 每次进⼊递归的时候,去备忘录⾥⾯看看;
- 每次返回的时候,将结果加⼊到备忘录⾥⾯。
动态规划:
- 递归含义 -&g