热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

dp按照规模分类总结

本文章的内容来源于花花酱dp2。做多了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


推荐阅读
  • 电话号码的字母组合解题思路和代码示例
    本文介绍了力扣题目《电话号码的字母组合》的解题思路和代码示例。通过使用哈希表和递归求解的方法,可以将给定的电话号码转换为对应的字母组合。详细的解题思路和代码示例可以帮助读者更好地理解和实现该题目。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • LeetCode笔记:剑指Offer 41. 数据流中的中位数(Java、堆、优先队列、知识点)
    本文介绍了LeetCode剑指Offer 41题的解题思路和代码实现,主要涉及了Java中的优先队列和堆排序的知识点。优先队列是Queue接口的实现,可以对其中的元素进行排序,采用小顶堆的方式进行排序。本文还介绍了Java中queue的offer、poll、add、remove、element、peek等方法的区别和用法。 ... [详细]
  • 给定一个二维平面上的一些点,通过计算曼哈顿距离,求连接所有点的最小总费用。只有任意两点之间有且仅有一条简单路径时,才认为所有点都已连接。给出了几个示例并给出了对应的输出。 ... [详细]
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 不同优化算法的比较分析及实验验证
    本文介绍了神经网络优化中常用的优化方法,包括学习率调整和梯度估计修正,并通过实验验证了不同优化算法的效果。实验结果表明,Adam算法在综合考虑学习率调整和梯度估计修正方面表现较好。该研究对于优化神经网络的训练过程具有指导意义。 ... [详细]
  • Python瓦片图下载、合并、绘图、标记的代码示例
    本文提供了Python瓦片图下载、合并、绘图、标记的代码示例,包括下载代码、多线程下载、图像处理等功能。通过参考geoserver,使用PIL、cv2、numpy、gdal、osr等库实现了瓦片图的下载、合并、绘图和标记功能。代码示例详细介绍了各个功能的实现方法,供读者参考使用。 ... [详细]
  • 本文介绍了机器学习手册中关于日期和时区操作的重要性以及其在实际应用中的作用。文章以一个故事为背景,描述了学童们面对老先生的教导时的反应,以及上官如在这个过程中的表现。同时,文章也提到了顾慎为对上官如的恨意以及他们之间的矛盾源于早年的结局。最后,文章强调了日期和时区操作在机器学习中的重要性,并指出了其在实际应用中的作用和意义。 ... [详细]
  • 本文讨论了如何使用IF函数从基于有限输入列表的有限输出列表中获取输出,并提出了是否有更快/更有效的执行代码的方法。作者希望了解是否有办法缩短代码,并从自我开发的角度来看是否有更好的方法。提供的代码可以按原样工作,但作者想知道是否有更好的方法来执行这样的任务。 ... [详细]
  • 怎么在PHP项目中实现一个HTTP断点续传功能发布时间:2021-01-1916:26:06来源:亿速云阅读:96作者:Le ... [详细]
  • 本文介绍了Python爬虫技术基础篇面向对象高级编程(中)中的多重继承概念。通过继承,子类可以扩展父类的功能。文章以动物类层次的设计为例,讨论了按照不同分类方式设计类层次的复杂性和多重继承的优势。最后给出了哺乳动物和鸟类的设计示例,以及能跑、能飞、宠物类和非宠物类的增加对类数量的影响。 ... [详细]
  • Day2列表、字典、集合操作详解
    本文详细介绍了列表、字典、集合的操作方法,包括定义列表、访问列表元素、字符串操作、字典操作、集合操作、文件操作、字符编码与转码等内容。内容详实,适合初学者参考。 ... [详细]
author-avatar
mobiledu2502870743
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有