动态规划与搜索算法

简介: 动态规划与搜索算法

动态规划(Dynamic Programming, DP)

动态规划是一种解决优化问题的算法设计技术,主要用于求解具有重叠子问题和最优子结构特性的最优化问题。在动态规划中,我们会将复杂问题分解为多个子问题,并计算子问题的解,然后通过组合子问题的解来构造原问题的解。通常,动态规划过程中会构建一张表格(或称为状态转移表),存储已经计算过的子问题的解,避免重复计算,从而降低时间复杂度。

搜索算法

(如深度优先搜索DFS、广度优先搜索BFS、Dijkstra算法、A*搜索等)则是用来探索图或树状结构以找到满足某种条件的路径或解的一种方法。搜索算法通常不强调重叠子问题和最优子结构,其重点在于遍历可能的解决方案空间,直至找到符合条件的目标状态

区别:

  1. 目的:动态规划主要用于求解最优化问题,而搜索算法主要用于找到从起点到终点的路径或其他满足条件的状态。
  2. 记忆化:动态规划往往涉及记忆化(Memoization)或填表,存储已经计算过的子问题答案以减少重复计算。搜索算法中也有类似的概念,如记忆化搜索,但它更侧重于避免回溯过程中的重复状态探索。
  3. 空间消耗:动态规划往往需要额外的空间存储中间结果,搜索算法则通常需要栈(DFS)或队列(BFS)来跟踪搜索路径,两者都会占用额外空间,但动态规划的记忆化表一般会更大。

具体事例:

  • 动态规划例子:斐波那契数列问题。要求计算第n个斐波那契数(F[n]),定义为F[0]=0, F[1]=1,F[n]=F[n-1]+F[n-2]。动态规划方法会创建一个数组来存储F[0]到F[n-1]的值,通过递推关系计算,避免了重复计算子问题。
for (int i = 2; i <= n; i++) {
    fib[i] = fib[i - 1] + fib[i - 2];
}
  • 搜索算法例子:迷宫问题。从起点出发寻找一条到达终点的路径。深度优先搜索会在搜索过程中标记已访问节点,以防回溯,一旦找到终点,返回路径。
bool dfs(Maze maze, Position current, Position target) {
   if (current == target) return true;
  maze[current] = Visited; // 标记已访问
   for (Position neighbor : maze.neighbors(current)) {
       if (!maze.isWall(neighbor) && !maze.isVisited(neighbor)) {
            if (dfs(maze, neighbor, target)) {
                maze.addPath(current, neighbor); // 记录路径
                return true;
            }
        }
    }
    return false; // 没有找到路径
}

在这两个例子中,斐波那契数列问题利用了动态规划减少了重复计算,而迷宫问题则是通过搜索算法探索可能的路径来找到解。

目录
相关文章
|
2月前
|
算法 测试技术 C++
【动态规划算法】蓝桥杯填充问题(C/C++)
【动态规划算法】蓝桥杯填充问题(C/C++)
|
1月前
|
算法 Python
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果;贪心算法在每一步选择局部最优解,追求全局最优;动态规划通过保存子问题的解,避免重复计算,确保全局最优。这三种算法各具特色,适用于不同类型的问题,合理选择能显著提升编程效率。
41 2
|
2月前
|
算法
动态规划算法学习三:0-1背包问题
这篇文章是关于0-1背包问题的动态规划算法详解,包括问题描述、解决步骤、最优子结构性质、状态表示和递推方程、算法设计与分析、计算最优值、算法实现以及对算法缺点的思考。
87 2
动态规划算法学习三:0-1背包问题
|
1月前
|
算法 搜索推荐 数据库
二分搜索:高效的查找算法
【10月更文挑战第29天】通过对二分搜索的深入研究和应用,我们可以不断挖掘其潜力,为各种复杂问题提供高效的解决方案。相信在未来的科技发展中,二分搜索将继续发挥着重要的作用,为我们的生活和工作带来更多的便利和创新。
45 1
|
2月前
|
算法
动态规划算法学习四:最大上升子序列问题(LIS:Longest Increasing Subsequence)
这篇文章介绍了动态规划算法中解决最大上升子序列问题(LIS)的方法,包括问题的描述、动态规划的步骤、状态表示、递推方程、计算最优值以及优化方法,如非动态规划的二分法。
76 0
动态规划算法学习四:最大上升子序列问题(LIS:Longest Increasing Subsequence)
|
2月前
|
算法
动态规划算法学习二:最长公共子序列
这篇文章介绍了如何使用动态规划算法解决最长公共子序列(LCS)问题,包括问题描述、最优子结构性质、状态表示、状态递归方程、计算最优值的方法,以及具体的代码实现。
159 0
动态规划算法学习二:最长公共子序列
|
2月前
|
算法 决策智能
基于禁忌搜索算法的VRP问题求解matlab仿真,带GUI界面,可设置参数
该程序基于禁忌搜索算法求解车辆路径问题(VRP),使用MATLAB2022a版本实现,并带有GUI界面。用户可通过界面设置参数并查看结果。禁忌搜索算法通过迭代改进当前解,并利用记忆机制避免陷入局部最优。程序包含初始化、定义邻域结构、设置禁忌列表等步骤,最终输出最优路径和相关数据图表。
|
2月前
|
存储 人工智能 算法
【算法——动态规划】蓝桥ALGO-1007 印章(C/C++)
【算法——动态规划】蓝桥ALGO-1007 印章(C/C++)
【算法——动态规划】蓝桥ALGO-1007 印章(C/C++)
|
2月前
|
存储 算法
动态规划算法学习一:DP的重要知识点、矩阵连乘算法
这篇文章是关于动态规划算法中矩阵连乘问题的详解,包括问题描述、最优子结构、重叠子问题、递归方法、备忘录方法和动态规划算法设计的步骤。
137 0
|
2月前
|
算法 C++
【算法解题思想】动态规划+深度优先搜索(C/C++)
【算法解题思想】动态规划+深度优先搜索(C/C++)