dp按照规模分类总结

本文章的内容来源于花花酱dp2。

做多了dp的题目之后总觉得有什么规律,但是自己没总结出来。花花酱按照输入规模、子问题个数、在解决一个问题的时候需要依赖的子问题个数为特征对题目做了分类。
在这里插入图片描述
其中绿色是比较简单的 ,黄色是中等的,粉色是比较难的。
对上面几种分类取其中一些做进一步分析,写出模板。

1.1

输入O(n)
有n个子问题需要解决
每个子问题依赖常数个更小的子问题
时间复杂度:O(n)
空间复杂度:O(n)->O(1)
模板

dp = [0] * n;
for i = 1 to n:dp[i] = f(dp[i-1],dp[i-2]...)return  dp[n]

LC 70:climbing stairs

dp[i] := 到达第i级台阶的方法
dp[i] = dp[i-2] + dpp[i-1]

LC 198: house robber

dp[i][0] :=0到i,抢第i个房间,抢到的最大价值。
dp[i][1] :=0到i,不抢第i个房间,抢到的最大价值。
dp[i][0] = max(dp[i-2][1],dp[i-2][0])+A[i]
dp[i][1] = max(dp[i-1][0],dp[i-1][1])

LC 801 Minimum Swaps To Make Sequences Increasing

dp[i][0] :=0到i,交换A[i]/B[i]的最小交换次数
dp[i][1] :=0到i,不交换A[i]/B[i]的最小交换次数

1.2

输入O(n)
有n个子问题需要解决
每个子问题依赖所有比它小的子问题
时间复杂度:O(n2n^2n2)
空间复杂度:O(n)
模板

dp = new int[n]
for i = 1 to n:for j = 1 to i-1:dp[i] = max/min(dp[i],f(dp[j]))
return dp[n]

LC 139 word break

dp[i] := wordbreak(A[0->i])
dp[i] = any(dp[k] && word(A[k+1->i]))

LC 818 race car

dp[i][0] :=到达位置i并且速度方向向右
dp[i][1] :=到达位置i并且速度方向向左
for  k in range(1,i):c = min(dp[k][0]+2,dp[k][1]+1)dp[i][0] = min(dp[i][0],dp[i-k][0]+c)dp[i][1] = min(dp[i][1],dp[i-k][1]+c) 

1.3

输入:O(m)+O(n)
dp[i][j] := 解决子问题(A[0->i],B[0->j])的答案
dp[i][j] 依赖常数个子问题的解
时间复杂度O(mn)
空间复杂度O(mn)
模板

dp =  new int[m][n]
for i = 1 to m :for j = 1 to n:dp[i][j] = f(dp[i-1][j-1],dp[i][j-1],dp[i-1][j])return dp[m][n]

LC 72 edit distance

dp[i][j] :=  从字符串A[0->i]变为B[0->j]最少操作数
dp[i][j] = f(dp[i-1][j-1],dp[i][j-1],dp[i-1][j])

1.4?

输入:O(n)
dp[i][j] :=子问题(A[i->j])的解,A[i->j]是输入的子串或者子数组
每个子问题依赖O(n)更小的子问题
模板

dp = new int[n][m]
for l  = 1  to  n:for i = 1 to l:j =  i+l-1for k = i to j:dp[i][j] = max(dp[i][j],f(dp[i][k],dp[k][j]))return dp[1][n]

LC 312 burst balloons

LC 664 strange printer

2.1

输入O(mn)
dp[i][j] := 解决子问题(A[0->i][0-j])的解
每个子问题依赖常数个子问题
时间 复杂度O(mn)
空间复杂度O(mn)
模板:

dp  = new int[m][n]
for i = 1 to m:for j =1  to n:dp[i][j] = f(dp[i-1][j],dp[i][j-1])return dp[m][n] / max(dp[m])

LC 62 unique paths

dp[i][j] :=  从A[]0[0]到A[i][j]有几种方式
dp[i][j] = dp[i-1][j] + dp[i][j-1]

2.2

输入O(mn)
dp[k][i][j] := 在k步之后解决子问题A[0->i][0-j])的解
每个子问题依赖一个子问题
时间复杂度O(kmn)
空间复杂度O(kmn)->O(mn)
模板

dp = new int[k][m][n]
for k = 1 to K:for i = 1 to m:for  j = 1 to  n:dp[k][i][j] =  f(dp[k-1][i+di][j+dy])return dp[K][m][n]/m(dp[K]) 

LC 576

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/424307.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

看了交大自产的电影《我的太阳》

呵呵,现在大学生自导自拍自演的电影越来越多了,不知道算是中国第几代导演:) 我看电影一般比较关注情节,演技暂且不提。因为是校园电影,本片自然比较接近大学生生活,总体情节比较浪漫曲折(虽然部…

【BZOJ4559】【JLOI2016】—成绩比较(拉格朗日插值+dp)

传送门 dpdpdpf[i][j]f[i][j]f[i][j]表示前iii门课,有jjj个人没有被碾压的方案数 考虑f[i−1][j]f[i-1][j]f[i−1][j]转移到f[i][w](j≤w)f[i][w](j\le w)f[i][w](j≤w) 首先要选出w−jw-jw−j个新的没被他碾压的人 由于之前已经有一些没被碾压的人,所以方案数为(n−…

中兴通讯 基于定位的技术和市场分析

中兴通讯 基于定位的技术和市场分析 (2004-08-10 09:04:27) 8月5日,由中国联通和中兴通讯联合举办的“中国联通位置业务研讨会”在海口举行。中国联通总部及多个省的分公司领导,应用中兴通讯PN4747定位系统开展定位业务的多家集团客户代表以及华好…

第八十三期:这些高性能负载均衡架构知识点,90%的人分不清!

单服务器无论如何优化,无论采用多好的硬件,总会有一个性能天花板,当单服务器的性能无法满足业务需求时,就需要设计高性能集群来提升系统整体的处理性能。 作者:马天池 单服务器无论如何优化,无论采用多好…

15. 3Sum-数组

文章目录1题目理解2 排序双指针1题目理解 输入:int数组nums 规则:查找数组中任意三个数的和等于0 输出:符合条件的解,不包含重复的解 例子: nums [-1, 0, 1, 2, -1, -4], A solution set is: [ [-1, 0, 1], [-1, -1…

第八十四期: Java、Web 和移动程序员学习的 12 个框架

今天的文章中,我将分享一些你可以学习的框架,以提升你在移动和Web开发以及大数据技术方面的知识。 作者:芒果教你学编程 在今天的文章中,我将分享一些你可以学习的框架,以提升你在移动和Web开发以及大数据技术方面的…

关于mysql无法添加中文数据的问题以及解决方案

所有能设置的地方我都设置了,都设置的是ut8。然后,我执行了一下insert语句,报错了!!!!!!!! 这个错误纠结了一天,最后,看到…

第八十五期:一文彻底搞懂cookie和session

在Web发展史中,我们知道浏览器与服务器间采用的是 http协议,而这种协议是无状态的,所以这就导致了服务器无法知道是谁在浏览网页,所以为了解决这一问题,先后出现了四种技术,分别是隐藏表单域,UR…

141. Linked List Cycle

文章目录1 题目理解2 分析13 分析21 题目理解 输入:一个单向链表。 输出:如果链表中有环,输出true。否则输出false。 规则:单向链表只能向前移动。 2 分析1 可以把节点放入map中,不断遍历。如果碰到已经遍历的节点&…

Microsoft Updater Application Block 1.5.3 服务器端manifest文件设计 [翻译]

Microsoft Updater Application Block 服务器端manifest文件设计 译者:Tony Qu Manfest文件用于列出一次升级所需要的所有的文件,它与验证签名相关联,验证签名可用于验证manifest文件的真实性。这个将介绍应用程序升级器的以下几个方面&#…

第八十六期:“程序员锁死服务器导致公司倒闭”案正式开庭审理

11 月 1 日,据微博网友爆料,此前程序员锁死服务器致创业游戏公司倒闭一案已经开庭审理,公司创始人“螃了个蟹” 提交了对方莫名失联,跑路的证据。 作者:51CTO 11 月 1 日,据微博网友爆料,此前…

delphi 参数化sql

曾经查过资料,后来忘了,现在做一下记录。 --------- 在 sql 语句里占位使用 一个冒号和一个用来表示这个位置的符号, 例如:SELECT * FROM aTableName WHERE aCol :ColVal SELECT * FROM aTableName WHERE aCol :ColVal 对占位了的地方赋值…

20 Valid Parentheses

1 题目理解 输入:一个字符串s,只包含( ) { } [ ]这六种字符。 输出:字符串是否有效 规则:一个有效的字符串需要括号对应匹配,并且要左括号在前。 举例: 1 输入s"()",输出true 2 Inpu…

SQL select 语法(转)

SQL 里面最常用的命令是 SELECT 语句,用于检索数据。语法是: SELECT [ ALL | DISTINCT [ ON ( expression [, ...] ) ] ]* | expression [ AS output_name ] [, ...][ INTO [ TEMPORARY | TEMP ] [ TABLE ] new_table ][ FROM from_item [, ...] ][ WHER…

spring mvc学习(9):路径参数

目录结构 web.xml <?xml version"1.0" encoding"UTF-8"?> <web-app xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance" xmlns"http://java.sun.com/xml/ns/javaee" xsi:schemaLocation"http://java.sun.com/xml…

mysql函数(五.流程控制函数)

流程控制函数 1.IF(expr1,expr2,expr3) 判断条件的正误&#xff0c;返回对应值 (1)判断条件的正返回expr2&#xff0c;否则返回expr3 select IF(10>5,大于,小于) as result; 结果&#xff1a;大于 2.IFNULL(expr1,expr2) 判断值是否为空 (1)判断值为空返回expr2&#x…

扩展String类

因为.Net Framework中的String类是封闭的&#xff0c;所以我们不能从它进行派生来扩展它的功能。 虽然String类已经提供了很多有用的方法来让我们进行字符串的处理和操作&#xff0c;但是有时候一些特殊的的要求还是不能能到满足。 一个例子就是&#xff1a;假如有一个因为句…

150 Evaluate Reverse Polish

1题目理解 输入&#xff1a;一个字符串数组。这个字符串数组表示算数运算的逆波兰表示法。一般算数表示方法是21&#xff0c;逆波兰表示是2 1 。 输出&#xff1a;一个int值。 Example 1: Input: [“2”, “1”, “”, “3”, “*”] Output: 9 Explanation: ((2 1) * 3) …

第八十七期:爬了知乎“沙雕问题”,笑死个人!

这两天偶然上网的时候&#xff0c;被知乎上一个名为“玉皇大帝住在平流层还是对流层”的问题吸引。 作者&#xff1a;数据森麟 这两天偶然上网的时候&#xff0c;被知乎上一个名为“玉皇大帝住在平流层还是对流层”的问题吸引。 图片来自 Pexels 本以为只是小打小闹&#xf…

django的url控制系统

无命名分组 &#xff08;\d{4}&#xff09; 有命名分组 &#xff08;&#xff1f;P<name>\d{4}&#xff09; 一个视图做两件事&#xff0c;提交方法不一样&#xff08;if 判断&#xff09; form action"/register/" django默认添加了当前面IP和端口 url别名…