【算法】算法设计与分析 课程笔记 第三章 动态规划

news/2025/2/12 21:26:48/

1.1 动态规划简介

1.1.1 引例

动态规划算法和分治法类似,基本思想也是将待求解问题分解成若干个子问题,子问题可以以继续拆分,直到问题规模达到临界条件即可。多说无益,举个例子来解释一下:

这其实是一个多阶段图求最短路的问题,路径大体上是 A→B→C→D→E,但是每到一个节点时就需要面临许多选择,所有选择中加起来最短的那一组就是要求的答案。

我们可以用动态规划的思想来分析这个问题,最开始从A出发,我们要选择一条最短的路,那么就可以把这个大问题先分成两个:从A到B和从B到E,这样就把大问题拆成两个小问题了,接下来,从A到B有两个选择,分别是B1和B2,它们和从B到E的路径相连,接下来就可以继续拆分,从B1到E和从B2到E又可以拆分成两个小问题,那就是从B到C和从C到E.......就这样一直拆下去,直到最后从D到E,这样再往回返回最短路径,直到得到整个问题的最短路径。

1.1.2 算法总体思想

从上面我们知道,动态规划算法也是不断地拆分问题,但是这里和之前的递归又有所不同,因为动态规划类的问题中,分解得到的子问题一般不会是相互独立的,也就是说有可能得到相同的子问题,所以在计算中,如果单单应用了递归,有些子问题就会被重复计算。

因此,适合使用动态规划来解决的问题一般都有下面两个性质:

1. 最优子结构性质

一个问题的最优解包含了其子问题的最优解。

2. 重叠子问题性质

在问题的求解过程中,很多子问题的解会被多次使用。

3.1 矩阵连乘问题


http://www.ppmy.cn/news/1139930.html

相关文章

【网络安全 --- kali2022安装】kali2022 超详细的安装教程(提供镜像)

如果你还没有安装vmware 虚拟机,请参考下面博客安装 【网络安全 --- 工具安装】VMware 16.0 详细安装过程(提供资源)-CSDN博客【网络安全 --- 工具安装】VMware 16.0 详细安装过程(提供资源)https://blog.csdn.net/m0…

Hortic Res. | 茶树中5mC DNA甲基化对组织功能分化和加工过程中风味代谢物变化的全面影响

2023年6月23日,中国农业科学院深圳农业基因组研究所张兴坦研究团队在Horticulture Research上发表题为“5mC DNA methylation modification-mediated regulation in tissue functional differentiation and important flavor substance synthesis of tea plant (Cam…

【Linux常用命令4】系统状态监测命令---2

last:查看所有系统的登录记录 执行last命令时,它会读取/var/log目录下名称为wtmp的文件,并把该文件记录的登录系统或终端的用户名单全部显示出来。默认显示wtmp的记录,btmp能显示的更详细,可以显示远程登录&#xff0…

BufferManager

之前写过一篇文章,讲解的是DMABuffer的,在第二章中有讲解:DMA Buffer在相机中的运用,讲解的就是 BufferManager的相关设计原理与思想,可以参考。

猜猜 JavaScript 输出:(! + [] + [] + ![]).length

一起猜 最近看到一个很有意思的题,直接来看,下面这段代码的打印结果是什么? console.log((! [] [] ![]).length) 猜猜看,你的答案是什么,打在评论区。 我的答案是 undefined,正如我的英文名 为什么呢&a…

html 笔记:CSS

1 什么是CSS CSS 指层叠样式表 (Cascading Style Sheets) 样式定义如何显示 HTML 元素样式通常存储在样式表中 1.1 css的语法格式 1.1.1 选择器种类 HTML选择器: 重新定义HTML的某种标签的显示格式id选择器 对于HTML文档中的某个标签,定义它的显示格式…

<HarmonyOS第一课>运行Hello World——闯关习题及答案

判断题 1.DevEco Studio是开发HarmonyOS应用的一站式集成开发环境。( 对 ) 2.main_pages.json存放页面page路径配置信息。( 对 ) 单选题 1.在stage模型中,下列配置文件属于AppScope文件夹的是?&#xff…

【好玩】如何在github主页放一条贪吃蛇

前言 🍊缘由 github放小蛇,就问你烧不烧 起因看到大佬github上有一条贪吃蛇扭来扭去,觉得好玩,遂给大家分享一下本狗的玩蛇历程 🥝成果初展 贪吃蛇 🎯主要目标 实现3大重点 1. github设置主页 2. git…