专题五:记忆化搜索

> 作者:დ旧言~
> 座右铭:松树千年终是朽,槿花一日自为荣。

> 目标:了解什么是记忆化搜索,并且掌握记忆化搜索算法。

> 毒鸡汤:有些事情,总是不明白,所以我不会坚持。早安!

> 专栏选自:递归、搜索与回溯算法_დ旧言~的博客-CSDN博客

> 望小伙伴们点赞👍收藏✨加关注哟💕💕

一、算法讲解

记忆化搜索(Memoization Search)

是一种通过存储已经遍历过的状态信息,从而避免对同一状态重复遍历的搜索算法。

主要特点和应用场景包括:

  1. 避免重复计算: 记忆化搜索算法通过缓存已经计算过的结果,以避免对相同输入进行重复计算。这在递归算法中特别有用,因为递归往往会导致相同的子问题被反复解决。
  2. 提高效率: 通过保存中间计算结果,记忆化搜索算法能够大幅减少算法的时间复杂度,从指数级别降低到多项式级别。

动态规划:

记忆化搜索在动态规划中经常被使用。动态规划是一种解决优化问题的方法,通常包含递归和子问题重叠的特点。记忆化搜索能够避免重复计算,使得动态规划算法更加高效。

递归算法优化:

记忆化搜索主要用于优化递归算法。在递归调用中,如果存在相同的输入参数,记忆化搜索算法将直接返回已经计算过的结果,而不是重新执行计算。

应用于搜索问题:

记忆化搜索不仅用于动态规划,还可以应用于搜索问题,特别是深度优先搜索中的状态记忆。

二、算法习题


2.1 第一题

题目链接:509. 斐波那契数 - 力扣(LeetCode)

题目描述:

算法思路:

暴搜:

  1. 递归含义:给 dfs ⼀个使命,给他⼀个数 n ,返回第 n 个斐波那契数的值;
  2. 函数体:斐波那契数的递推公式;
  3. 递归出⼝:当 n == 0 或者 n == 1 时,不⽤套公式。

记忆化搜索:

  1. 加上⼀个备忘录;
  2. 每次进⼊递归的时候,去备忘录⾥⾯看看;
  3. 每次返回的时候,将结果加⼊到备忘录⾥⾯。

动态规划:

  1. 递归含义 -&g
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值