算法设计与分析之动态规划法

article/2025/9/29 21:33:25

文章目录

  • 前言
  • 一、动态规划法概述
  • 二、动态规划法设计思想
  • 三、动态规划法的基本要素
  • 四、动态规划算法的设计步骤
  • 五、动态规划法与分治法
  • 六、动态规划法与贪心法
  • 七、动态规划法示例
  • 总结


前言

        大家好,我是一只勤勤恳恳的程序猿。本篇文章小猿将跟您分享算法设计与分析中的动态规划法,希望对大家有所帮助。

在这里插入图片描述

一、动态规划法概述

        动态规划是运筹学的一个分支,它是解决多阶段决策过程最优化问题的一种方法。 动态规划主要用于求解以时间划分阶段的动态过程的优化问题,但是一些与时间无关的静态规划(如线性规划、非线性规划),可以人为地引进时间因素,把它视为多阶段决策过程,也可以用动态规划方法方便地求解。
        这里需要深入的理解一下几个概念:
        1、多阶段决策问题
        可以分为若干个相互联系的阶段,每个阶段都要做出一个决策,这个决策即决定了本阶段的效益,也决定了下一阶段的初始状态。当每一个阶段的决策确定后,就得到一个决策序列,称为策略。多阶段决策最优化问题就是求得一个策略,使各个阶段的效益总和达到最优。
        2、多阶段决策过程
        问题的解由该问题的n个输入的一个子集组成,这个子集必须满足某些事先给定的条件,这些条件称为约束条件。满足约束条件的解称为问题的可行解。衡量所有可行解的优劣,通常以函数的形式给出一定的标准,这些标准函数称为且标函数(或评价函数)。使目标函数取得极值(极大或极小)的可行解称为最优解。具有上述这些要素的问题称为最优化问题。
        3、最优化问题
        最优化问题的求解可以划分为若干个阶段,每一阶段的决策仅依赖于前一阶段的状态,由决策所采取的动作使状态发生转移,成为下一阶段决策的依据。
        状态:表示每个阶段开始时,问题或系统所处的客观状况。状态既是该阶段的某个起点, 又是前一个阶段的某个终点。通常一个阶段有若干个状态。
状态无后效性:如果某个阶段状态给定后,则该阶段以后过程的发展不受该阶段以前各阶段状态的影响,也就是说状态具有马尔科夫性。适于动态规划法求解的问题具有状态的无后效性。
        策略:各个阶段决策确定后,就组成了一个决策序列,该序列称之为一个策略。一个决策序列在不断变化的状态中产生,这个决策序列产生的过程称为多阶段决策过程。
在这里插入图片描述
        最优性原理:无论决策过程的初始状态和初始决策如何,其余的决策都必须相对于初始决策所产生的当前状态,构成一个最优决策序列。
在这里插入图片描述

二、动态规划法设计思想

        动态规划算法与分治法类似,其基本思想也是将待求解问题分解成若干个子问题
在这里插入图片描述
        但是经分解得到的子问题往往不是互相独立的。不同子问题的数目常常只有多项式量级。在用分治法求解时,有些子问题被重复计算了许多次。
在这里插入图片描述
        如果能够保存已解决的子问题的答案,而在需要时再找出已求得的答案,就可以避免大量重复计算,从而得到多项式时间算法。
在这里插入图片描述

三、动态规划法的基本要素

1、子问题重叠性质
        (递归算法求解问题时)每次产生的子问题并不总是新问题,有些子问题被反复计算多次,这种性质称为子问题重叠性质。
        动态规划算法对每一个子问题只解一次,而后将其解保存在一个表格(通常用维数组) 中, 当再次需要解此子问题时,只是简单地用常数时间查看下结果。
        通常不同的子问题个数随问题的大小呈多项式增长。因此用动态规划算法只需要多项式级时间,从而获得较高的解题效率。

2、最优子结构性质一一用动态规划法求解的前提
        当一个问题的最优解包含了其子问题的最优解时,称该问题具有最优子结构性质。
        一个问题的活动过程可以分为若干个阶段,每个阶段可包含一个或多个状态,从初始阶段的初始状态出发做出每个阶段的决策,形成一个决策序列。
        利用问题的最优子结构性质,以自底向上的方式递归地从子问题的最优解逐步构造出整个问题的最优解。
        用反证法说明问题的最优子结构性质。

四、动态规划算法的设计步骤

用动态规划算法求解问题的步骤
        1、找出最优解的性质,并刻划其结构特征。(划分子问题)
        最优子结构性质:问题的最优解包含其子问题的最优解。(显著特征)
        2、递归地定义最优值。(确定动态规划函数)
建元递归关系式
        3、以自底向上的方式计算出最优值。
        4、根据计算最优值时得到的信息,构造最优解。(此步只在要求得到最优解时才需要做)

注意点
        1、动态规划法是一种求解最优化问题的重要算法策略。
        2、动态规划法的子问题往往是重叠的。如果采用与分治法类似的直接递归方法求解将十分费时。为了避免重复计算,动态规划算法一般采用自底向上方式进行计算,并保存已经求解的子问题的最优解值。
        3、利用最优子结构性质及所获得的递推关系式(较小子问题最优解与较大子问题最优解之间存在的数值关系)去求取最优解,可以使计算量较之穷举法急剧减少。

五、动态规划法与分治法

共同点

        将待求解的问题分解成若干子问题,先求解子问题,然后再从这些子问题的解得到原问题的解。

不同点

        1、适合于用动态规划法求解的问题,分解得到的各子问题往往不是相互独立的;而分治法中子问题相互独立。
        2、动态规划法用表保存已求解过的子问题的解,再次碰到同样的子问题时不必重新求解,而只需查询答案,故可获得多项式级时间复杂度,效率较高;而分治法中对于每次出现的子问题均求解,导致同样的子问题被反复求解,故产生指数增长的时间复杂度,效率较低。

六、动态规划法与贪心法

共同点

        都是求解最优化问题;都具有最优子结构性质。

不同点

1、求解方式不同
        动态规划法:自底向上;
        贪心法:自顶向下。以迭代的方式作出相继的贪心选择,每作一次贪心选择就将所求问题简化为一个规模更小的子问题。
2、对子问题的依赖不同
        动态规划法:依赖于各子问题的解。只有在解出相关子问题后,才能作出选择;应使各子问题最优,才能保证整体最优;
        贪心法:不依赖于子问题的解。仅在当前状态下作出最好选择,即局部最优选择。

七、动态规划法示例

1、0/1背包问题
2、数塔问题
3、矩阵连乘问题
4、最长公共子序列
5、最优二叉查找树
6、多段图的最短路径问题

总结

知识点总结
1、动态规划法的设计思想
        把求解的问题分成许多阶段或多个子问题,然后按顺序求解各子问题,最后一个子问题就是初始问题的解。
2、动态规划算法的基本要素
        最优性原理、子问题重叠性
3、设计动态规划算法的基本步骤
        (1)、分析最优解的性质,并刻划其结构特征;
        (2)、递归地定义最优值;
        (3)、以自底向上的方式计算出最优值;
        (4)、根据计算最优值时得到的信息,自顶向下构造最优解。

结语

        对动态规划法的介绍就到这里啦,希望这篇文章能给予你一些帮助,感谢各位人才的:点赞、收藏和评论,我们下次见。

在这里插入图片描述


http://chatgpt.dhexx.cn/article/TRabJiST.shtml

相关文章

算法-动态规划法

动态规划是在20世纪50年代由美国数学家贝尔曼为研究最优控制问题而提出的,当该方法在应用数学中的价值被大家认同以后,在计算机学界,动态规划法成为一种通用的算法设计技术用来求解多阶段决策最优化问题。 所以,同学们&#xff0…

动态规划算法

一 动态规划算法 动态规划(Dynamic Programming)算法的核心思想是:将大问题划分为小问题进行解决,从而一步步获取最优解的处理算法。 动态规划算法与分治算法类似。其基本思想也是将待求解问题分解成若干个子问题,先求解子问题,…

经典中的经典算法:动态规划(详细解释,从入门到实践,逐步讲解)

动态规划的重要性就不多说,直接进入正题 首先,我们看一下官方定义:定义: 动态规划算法是通过拆分问题,定义问题状态和状态之间的关系,使得问题能够以递推(或者说分治)的方式去解决。 动态规划算法的基本思想与分治法类似&#xf…

目标检测中的多尺度特征结合方式

目录 简述 解构物体检测各个阶段 FPN的演进 1)无融合 2)自上而下单向融合 a)Faster/Master/Cascade RCNN中的FPN b)RetinaNet中的FPN c)Yolov3中的FPN 3)简单双向融合 4)复杂的双向融…

总结-CNN中的目标多尺度处理

Fly-AI竞赛服务平台 flyai.com 在开始学习之前推荐大家可以多在 FlyAI竞赛服务平台多参加训练和竞赛,以此来提升自己的能力。FlyAI是为AI开发者提供数据竞赛并支持GPU离线训练的一站式服务平台。每周免费提供项目开源算法样例,支持算法能力变现以及快…

【MFEN:轻量级多尺度特征提取:SR网络】

MFEN: Lightweight multi-scale feature extraction super-resolution network in embedded system (MFEN:嵌入式轻量级多尺度特征提取超分辨率网络) 深度卷积神经网络(CNN)在超分辨率(SR)方面…

深度学习笔记---多尺度网络结构归类总结

目录 1.什么是图像金字塔 1.1 高斯金字塔 ( Gaussian pyramid): 1.2 拉普拉斯金字塔(Laplacian pyramid) 1.3 DOG金字塔 2. 多尺度网络(MTCNN) 2.1 多尺度输入网络 2.2 多尺度特征融合网络 2.2.1 并行多分支网络 2.2.2 串行…

【边缘注意:深度多尺度特征】

Learning a Deep Multi-Scale Feature Ensemble and an Edge-Attention Guidance for Image Fusion (学习深度多尺度特征集成和图像融合的边缘注意指南) 在本文中,我们提出了一种用于红外和可见光图像融合的深度网络,该网络将具…

多尺度特征的提取

1、图像金字塔 将图片进行不同尺度的缩放,得到图像金字塔,然后对每层图片提取不同尺度的特征,得到特征图。一幅图像的金字塔是一系列以金字塔形状排列的分辨率逐步降低,且来源于同一张原始图的图像集合。其通过梯次向下采样获得&…

MSRN(多尺度超分辨率重建)

目前的研究倾向于使用更深层次的卷积神经网络来提高性能。然而,盲目增加网络深度不能有效改善网络。更糟糕的是,随着网络深度的增加,训练过程中出现了更多的问题,需要更多的训练技巧。在本文中,我们提出了一种新颖的多尺度残差网络 (MSRN) 来充分利用图像特征,该网络优于…

【multi_scale】多尺度训练——目标检测训练trick

文章目录 1 多尺度训练的介绍2 代码解析3 感谢链接 1 多尺度训练的介绍 多尺度训练对全卷积网络有效,在训练时,每隔一定的 iterations,在一定尺寸范围内,随机选取一种 img_size 进行训练。通过对不同尺度的图像进行训练&#xff…

“多尺度”目标检测问题

一、“多尺度”目标检测问题简介 在目标检测任务中,被测目标的大小经常是不固定的,自动驾驶相关检测任务可能要同时检测大卡车与小狗;工业质检相关检测任务可能要同时检测布料的大面积撕裂与小穿孔;医疗病灶检测任务可能要同时检测大小不一的病灶。在被测物体尺度相差极大…

图像多尺度技术

1197 多尺度图像技术也叫做多分辨率技术(MRA),指对图像采用多尺度的表达,并且在不同尺度下分别进行处理。这样做的理由是很多情况下在一种尺度中不容易看清的或者获取的特性在另外的某种尺度下就很容易发现或者是提取。所以多尺度…

目标检测中多尺度:特征金字塔FPN_Feature Pyramid Networks for Object Detection

原始内容来源于: https://blog.csdn.net/cdknight_happy/article/details/100528127 https://blog.csdn.net/WZZ18191171661/article/details/79494534 包含理解! 参考文献:https://arxiv.org/abs/1612.03144 代码实现:http://ww…

MViTv2 多尺度视觉Transformer

虽然VIT(vision transformer)模型提出后,Transformer在CV领域一路攻城拔寨,不断刷新由自己创下的记录,但VIT文章中所说明的视觉领域transformer很大程度上受transformer模型平方复杂度的限制而在大尺度图像上表现不佳的…

综述:目标检测中的多尺度检测方法

传统卷积网络通常采用从上到下的单行结构。对于大物体而言,其语义信息将出现在较深的特征图中;而对于小物体,其语义信息出现在较浅的特征图中,随着网络的加深,其细节信息可能会完全消失。 多尺度检测也是当今物体检测领…

【笔记】多尺度方法

1.定义 2.常用架构 2.1多尺度输入网络 2.2 多尺度特征融合网络 (1) 并行多分支结构 (2) 串行多分支结构 2.3 多尺度特征预测融合 2.4 多尺度特征和预测融合 3.具体方法 3.1 SNIP 3.2 SNIPER(SNIP的改进) 3.3 SSD 3.4 TridentNet(…

多尺度多目标检测之金字塔

在日常学习工作中,经常会碰到一个概念,那就是金字塔(pyramid),本文就该概念进行一定的阐述,具体如下: (1)图像金字塔 图像金字塔结构,即对图像进行一定比例…

多尺度结构元素形态学边缘检测算法的研究-含Matlab代码

目录 一、引言二、数学形态学理论概述三、实验验证四、参考文献五、Matlab代码获取 一、引言 使用数字图像处理技术来解决计算机视觉、人工智能、生物遥感器视觉等领域所涉及到的图像问题时,最重要、最关键的一步是提取出图像中最有效、最有用的特征信息。而图像边…

多尺度熵---Understanding Multiscale Entropy

目录 导言计算多尺度熵多尺度熵在脑电分析中的应用参考文献 导言 多尺度熵(Multiscale entropy, MSE)将样本熵扩展到多个时间尺度,以便在时间尺度不确定时提供额外的观察视角。样本熵的问题在于它没有很好地考虑到时间序列中可能存在的不同时…