Dynamic programming

本文针对两篇优秀动态规划文章中存在的不易理解的部分:状态、状态转移的定义和状态转移方程的编程实现部分进行个人解读。欢迎指出本文存在的错误和表述不清之处。

DP概述

DP(Dynamic Programming)是算法设计中解决最优化问题(eg: 最长公共子序列)的重要思想。
(待补充)
因此我们可以得出结论:

动态规划的本质,是对问题状态的定义和状态转移方程的定义。
——什么是动态规划?动态规划的意义是什么?(徐凯强 Andy的回答)

状态

这里给出我自己的一个定义后面会解释:

从“原始的最优化问题”剥离出的每个“最优化子问题”都是当前DP问题的一个状态,每个状态分布在“每次的决策前后”。

我们现在来看两个简单的动态规划问题:

问题1:
给定一个数列A,长度为N,
求这个数列的最长上升(递增)子数列(LIS)的长度.

1 7 2 8 3 4
为例。
这个数列的最长递增子数列是 1 2 3 4,长度为4;
次长的长度为3, 包括 1 7 8; 1 2 3 等.

剥离出的子问题,以及等价最终问题:
给定一个数列A,长度为N
设F(x):以数列A中第x项结尾的最长递增子序列的长度, 其中0 <= x <= N 。(子问题or状态)
求F(1)..F(N)中的最大值 (等价最终问题)

问题2:
如果我们有面值为1元、3元和5元的硬币若干枚,如何用最少的硬币凑够11元?

剥离出的子问题,以及等价最终问题:
如果我们有面值为1元、3元和5元的硬币若干枚
设D(i):凑够i元使用最少硬币个数,其中 0 <= i <= 11。(子问题or状态)
求D(11)的值。 (等价最终问题)

这两个问题便是“原始的最优化问题”。现在,根据“状态和状态转移方程的定义是动态规划的本质”的结论,我们需要做的就是从“原始的最优化问题”中找出状态,然后再得到状态转移方程,之后根据状态转移方程实现代码(其间还会使用到记忆和重叠子问题特性),最终得到解。

  • 剥离子问题,获得状态(最需要技巧和训练的部分)
    之前说过,DP中的状态就是子问题。显然,我们要获得状态就必须剥离(拆分)“原始的最优化问题”。这里通过分析问题1和问题2剥离好的子问题探索一下DP中剥离(拆分)问题的“奇淫巧技”。

    首先拿到一个DP问题,我们最先要思考的是: 该问题的“变数”在哪里?这里的“变数”很重要,问题的“变数”往往是整个问题定义中的一个参数,当我们改变这个参数时,将会使问题的规模缩小。 例如,问题1的变数是数列A的大小,当我们改变数列A的大小时,问题1的规模变缩小了。因此,我们才这样剥离问题1:"F(x)是以A[x]为结尾的LIS的长度,且 0<= x <= N"。显然,此时若x 等于 N-1,我们把问题缩小了单位1长度;此时若x等于0,我们则把问题缩小成了0,显然此时还触碰到了当前问题的边界:“数列长度必须大于等于0”。问题2中也可套用同样的思路: 我们可以把最终需要凑够的价格i元作为变数,当我们改变i元的大小时,问题2的规模同样被缩小了。因此我们才这样重新定义问题2:"D(i)是凑够i元需要的最少硬币个数"。此时若i等于0,我们同样到达了当前问题的边界:"凑钱不可能凑出负数"。

    因此,DP剥离子问题需要多联系"当前问题中可能的变数",同时多加练习。

  • DP中每个子问题都是状态,分布在每次决策前后
    把DP中的子问题问题叫做状态有两方面原因。

  • 为了区分问题和子问题而产生的叫法。

之所以把Fx叫做“状态”而不是“问题” ,一是因为避免跟原问题中“问题”混淆,二是因为这个新问题是数学化定义的。
——什么是动态规划?动态规划的意义是什么?(徐凯强 Andy的回答)

  • 状态二词更能准确表示出DP子问题是什么

从前面对剥离子问题的分析大抵可以感受到这么一个过程: 整个DP问题从问题的定义边界开始(比如: 数列之长度为0,凑钱之总额为0),到问题收敛处为止(比如: 数列之长度为N,凑钱之总额为0),算法的每次决策都在推动前一个子问题发展到后一个子问题,往往这种推动都有多种可能性

比如:A={1 7 2 8 3 4},从当前F(3)={1,2}到F(6)时,我们可以很机智地选择从F(5) = {1,2,3}走最优解到F(6)={1,2,3,4}。但我们也可以任性地选择F(5)={1,2}到F(6)={1,2,4},或者F(5)={1,2,3},F(6)={1,2,3}..以及其他多种可能性)。此时我们可以在子问题之间以不同的状态(如F(5)={1,2,3} 或者F(5)={1,2})进行转移(比如从F(5)={1,2,3}到F(6)={1,2,3,4}),因此把子问题叫做“状态”,把子问题间的转移叫做“状态转移”是很形象的说辞。

状态转移方程

对状态的解释已经触及到了状态转移的概念:“子问题间通过决策进行推演的过程叫做状态转移”。所以,状态转移方程就应该是“子问题间通过决策定义的等式关系叫做状态转移方程”,通常状态转移方程和当前问题的边界条件联立起来叫做状态转移方程式。


——什么是动态规划?动态规划的意义是什么?(徐凯强 Andy的回答)


——动态规划:从新手到专家

显然,max(), min()就代表着一种最优决策。我们如果把max或者min去掉,那么上面的方程式依然可以叫做状态转移方程,只是得到的结果不一定是最优解了。

编程实现

初学者在解DP问题时,如何编程实现状态转移方程?如何在DP求解过程中利用重叠子问题进行记忆求解?
让我们看一下问题2的伪代码:


从伪代码我们可以分析出一个较为通用的DP代码实现过程:(S代表总额,N-1代表可能的硬币面值)

  • 首先我们需要存储每个子问题的最优解,比如伪代码中使用Min[i]数组存储每个子问题的最优解。
  • 然后我们需要对DP问题的边界的解进行初始化,比如伪代码中Min[0] = 0代表着边界条件"凑够0元需要的最少硬币数"的解。
  • 定义好边界解后,我们就可以从边界解开始,使用递归的方法自底向上的求解DP的每个子问题,并把子问题的最优解记录下来。比如,伪代码中从i = 1开始求解直到i = s,每次得到的子问题最优解都被存储在Min[i]中。
  • 最后,根据特定的题目,或直接输出某个子问题的最优解,或对所有子问题的最优解进行处理以后再进行输出。比如:硬币问题我们可以直接输出Min[11]。而LIS问题我们需要比较F(x),x = 0,1,2...N, 然后输出F(x)的最大值。

引用

什么是动态规划?动态规划的意义是什么?
http://www.hawstein.com/posts/dp-novice-to-advanced.html
动态规划:从新手到专家
https://www.zhihu.com/question/23995189

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容