理解不了动态规划会对后端程序员职业发展有哪些影响?

2021-05-17 19:06:14 +08:00
 zhoudaiyu

普通后端程序员,非算法岗

4924 次点击
所在节点    程序员
33 条回复
raaaaaar
2021-05-17 23:13:21 +08:00
以前我也挺害怕的,后来学了算法课和数学建模,其实也没有那么恐怖。

你要说什么计算,操作系统啥的可能对真正开发会有影响,但是这个东西就纯面向面试的东西吧
raaaaaar
2021-05-17 23:54:39 +08:00
贪婪,动态规划,分治,都是把一个复杂的问题划分为子问题来解。

贪婪是每个子问题都是最优的,但是最终问题一般不是最优解。

分治的子问题一般是独立的,能够单独求解出来,比如说归并和快排,分成两个子问题排序时,其他子问题是不会影响的。分治的思想就是先分,再治。子问题的类型一般类似,求解方式一样,所以一般用递归,求解完子问题后,再合并求解原问题,比如说二叉树就是一个很常用的分治思想,因为二叉树从定义上来说就是一个递归式的,都能划分为三个节点的子问题,所以很多算法都是差不多的模板。

而动态规划也是把问题划分为子问题,但是在求解的过程中,子问题有些重复出现了,这个时候我们可以时空权衡,也就是空间换时间,把子问题的解记录下来帮助求解,比如说经典的求斐波那契数列,求 f(6)要算 f(5) 和 f(4),这里要算一边 f(4),而求 f(5)?时又要求 f(4) 和 f(3),显然 f(4) 就重复计算了,那么我们就可以提前把结果存下来,以后用的时候直接查找就行了。转换为迭代就是这个思想。

那么一般什么问题适合动态规划呢?
子问题重复:子问题有重复的,这是动态规划优化的原理,当然子问题如果没有重复也可以做,不过就没有意义了。
无后向性:把问题划分为子问题后,通常子问题是一个线性的链,这个链要是一个马尔可夫链,也就是说,后面阶段(子问题)的解,只和现在这个阶段的解有关,而和以前的解无关。比如求 f(6) 时,结果就只和前一个阶段的 f(5) 和 f(4) 有关,而和其他的无关。
最优化原理:和贪婪一个思想,也就是说,每个阶段的解必须是最优的,而且通常需要先证明,最终问题的最优解等价于局部各阶段最优,这个时候才会使用动态规划。

动态规划的实质是什么?
分治+时空权衡解决冗余

那么动态规划应该具体怎么做?
分析问题的结构,看它是不是满足上面的三个原则,或者能转换为类似的问题。比如说,f(6) 能分为 f(4) 和 f(3),这就是一个阶段,并且阶段有重复的,那么这个问题就能用动态规划来做。一般可以画决策树来帮助理解,也就是说,要解决这个问题,需要解决那些问题?这样一层层的分析下去的一棵树。

递归求解。我们可以从原问题开始一个阶段一个阶段的往下求解,也可以反过来从最低的阶段求解,而在这个过程中,我们通常会发现不同阶段间的转移是有规律的,通常问题的重点就在于如何找到这个状态转移方程。

根据得到的值,求解最优值。

在找转移方程的时候,问题怎么分阶段,每个阶段具体和什么信息有关,又怎么用符号来表示一个阶段,最后才是怎么找出阶段间的关系。通常动态规划中有一种常见的划分阶段的方式,那就是选择还是不选择这样二元的关系。

比如说在组合问题中,要对 n 个数选择 k 个数,我们一个个的选,对于每一个数,就有选或者不选两种可能,如果第一个数选,那么还需要从 n-1 个数里选 k-1 数出来,如果选,那么需要从 n-1 个数里选 k 个数,最终的结果就是这两种情况的和。在这里我们以数的选与不选作为阶段,同时也自然推出了转移方程,最终的结果是和,但是比如背包,或者最短路径中,通常是多个值的最值。
fantastM
2021-05-18 00:53:42 +08:00
> 有点恐惧动态规划......

曾经我也是这样,一度怀疑自己的智商,但当我逐字逐句地看完《算法导论》之后,我就不再害怕了
beidounanxizi
2021-05-18 01:21:45 +08:00
大部分面试官水平也不会超过 codeforce 2K 以上的
做不出来 大概率是刷题不够 又容易忘记吧
786375312123
2021-05-18 01:27:56 +08:00
到目前为止 FAANG 面了个遍,一次动态规划都没遇到过
binux
2021-05-18 02:22:50 +08:00
那要不你找找你擅长的?
Hsinyao
2021-05-18 02:45:40 +08:00
当然没有影响,但是面试就是要问啊,不会就没有工作,那能怎么办呢
Mirage09
2021-05-18 03:07:11 +08:00
我个人觉得面试面 dp 还要最优解是件很无聊的事情…
JoStar
2021-05-18 09:37:30 +08:00
@fantastM 这本书真有这么强?适合新手?
fantastM
2021-05-18 09:58:12 +08:00
@JoStar #29
> 这本书真有这么强?
英文版豆瓣 9.5 分,中文版豆瓣 9.2 分

> 适合新手?
书中的译者序章节说,这书是斯坦福大学的教材
woodensail
2021-05-18 15:00:39 +08:00
@powerman 你理解错他的意思了,他的意思是所有计算过的数据都存下来,省得下次重新算。至于计算方式是啥并不重要。
cornetCat
2021-05-19 15:33:12 +08:00
b 站有个 up 讲这个感觉讲的很好,正月点灯笼( https://space.bilibili.com/24014925/)非常推荐
zhoudaiyu
2021-05-19 18:56:21 +08:00
@cornetCat #32 感觉这个 up 主讲的很不错啊,感谢感谢

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/777499

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX