[LeetCode] 系统刷题5_Dynamic Programming
Dynamic Programming 实际上是[LeetCode] 系统刷题4_Binary Tree & Divide and Conquer的基础上,加上记忆化的过程。就是说,如果这个题目实际上是类似于Divide and conquer或者说是DFS,但是在计算过程中有很多重复计算同样的过程的话,那么就可以用Dynamic prgramming/记忆化搜索来完成。基本就是利用空间来简化时间复杂度的过程。
可以/很有可能使用Dynamic programming的条件,满足之一即可。
1. Maximum/Minimum
2. Yes/No. True/False
3. Count(*)
一定不是Dynamic programming的条件,满足之一即可。
1. all 具体方案。
2. input是集合或者跟position无关。
3. move 4 directions in 二维数组。(或者说不是固定方向,有可能会有循环)
动态规划4要点:
1. 状态 state
mem[i][j] 代表什么,ex. 代表s1前i个characters和s2前j个characters。
2. Function
mem[i][j] = mem[i - 1][j] if ****
3. Initialize
usually mem[0][0] / mem[i][0]/ mem[0][j]
4. 答案
mem[n]/mem[n - 1]/mem[m][n]
在这里将Dynamic programming分为几类。
1. 矩阵Dynamic programming/Matrix DP
state: mem[i][j] 走到坐标(x, y) 的状态。
[LeetCode] 120. Triangle _Medium tag: Dynamic Programming
[LeetCode] 64. Minimum Path Sum_Medium tag: Dynamic Programming
[LeetCode] 62. Unique Paths_ Medium tag: Dynamic Programming
[LeetCode] 63. Unique Paths II_ Medium tag: Dynamic Programming
2. Sequence DP
state: mem[i] 前i个位置
mem 的length 设为n
[LeetCode] 70. Climbing Stairs_ Easy tag: Dynamic Programming
[LeetCode] 55. Jump Game_ Medium tag: Dynamic Programming
[LeetCode] 45. Jump Game II_ Hard tag: Dynamic Programming
3. 分割DP
state: mem[i] 前i个character 是否可行
mem 的length 设为n + 1,因为要考虑到前0个character,也就是empty string。
[LeetCode] 132. Palindrome Partitioning II_ Hard tag: Dynamic Programming
[LeetCode] 139. Word Break_ Medium tag: Dynamic Programming
4. Two sequences DP
state: mem[i][j] 表明s1的前i个characters, 配上s2的前j 个characters。
mem 的length 设为(n + 1)* (m + 1),因为要考虑到前0个character,也就是empty string。
需要初始化 mem[i][0], mem[0][j]
[LintCode] 77. Longest common subsequences_ Medium tag: Dynamic Programming
[LeetCode] 72. Edit Distance_hard tag: Dynamic Programming
[LeetCode] 115. Distinct Subsequences_ Hard tag: Dynamic Programming
[LeetCode] 97. Interleaving String_ Hard tag: Dynamic Programming
[LeetCode] 系统刷题5_Dynamic Programming的更多相关文章
- [LeetCode] 系统刷题1_代码风格及边界
代码风格 说自己不清楚的算法,比如KMP,如果解释不清楚或者写不出来的算法建议不提 注意代码的缩进以及空格的合理运用,使得代码看起来比较整洁有条理 注意边界的条件以及越界 误区: 算法想出来还仅仅不够 ...
- [LeetCode] 系统刷题4_Binary Tree & Divide and Conquer
参考[LeetCode] questions conlusion_InOrder, PreOrder, PostOrder traversal 可以对binary tree进行遍历. 此处说明Divi ...
- [LeetCode] 系统刷题3_Binary search
可以参考 [LeetCode] questions conclusion_ Binary Search
- [LeetCode] 系统刷题2_排列组合
要用到backtracking,是否要跟backtracking放到一起总结? 适用范围: 几乎所有搜索问题 什么时候输出 哪些情况需要跳过 相关题目: [LeetCode] 78. Subsets ...
- [LeetCode] 系统刷题6_Linked List
1. Dummy Node 2. Basic skills [LeetCode] 206. Reverse Linked List_Easy tag: Linked List 2. Fast slow ...
- LeetCode的刷题利器(伪装到老板都无法diss你没有工作)
在工程效率大行其道的今天,如果不会写点代码以后也不容易在测试圈混下去.今天给大家推荐一个LeetCode的刷题利器,可以伪装到连你老板在这里走过去都无法确认你是在干活呢,还是在干活呢. LeetCod ...
- leetcode top-100-liked-questions刷题总结
一.起因 宅在家中,不知该做点什么.没有很好的想法,自己一直想提升技能,语言基础自不必言,数据结构还算熟悉,算法能力一般.于是乎,就去刷一通题. 刷题平台有很多,我选择了在leetcode进行刷题.回 ...
- LeetCode 高效刷题路径
LeetCode 高效刷题路径 Hot 100 https://leetcode.com/problemset/hot-100/ https://leetcode-cn.com/problemset/ ...
- leetcode 算法刷题(一)
今天开始刷Leetcode上面的算法题.我会更新我刷题过程中提交的代码(成功和不成功的都有)和比较好的解法 第二题 Add Two Numbers 题目的意思:输入两个链表,这两个链表都是倒序的数字, ...
随机推荐
- autofac生命周期入门(如何避免内存泄漏)
如果你是一个IOC新手,那么生命周期可能会比较难以理解.以至于谈到这个问题时,一些老手也时常表示疑虑和害怕.一个令人不安的问题就是-对象没有在合适的时机被销毁.这样一来内存的使用率就会一直攀升,直到程 ...
- [No0000143]Win10“卓越性能模式”
从不久之前Win10更新1803以来,微软不仅带来了一些新功能(和BUG),还悄悄地加入了一个“卓越性能模式”,老张想了想,不对呀,以前就有了一个“高性能模式”,这怎么就还多出个新的性能模式来,难道会 ...
- Python:正则表达式
学习内容参考:Python正则表达式指南 匹配流程 语法表
- 使用qemu模拟调试内核和debian根文件系统
开发环境:Ubuntu 14.04.3 LTS 64bit sudo debootstrap jessie /mnt/jessie http://mirrors.163.com/debian 在 ...
- JavaScript面向对象之函数构造器的理解
1,在使用函数创建类时,函数本身也被称为该类的构造器,该类的构造器方法,该类的构造方法,该类的构造函数等等. 2,注意构造器方法是没有返回值的,当创建该类的实例时,必须调用该类的构造方法. 3,获取构 ...
- Appium入门(3)__ Appium Server安装
安装Appium 1.下载并安装:https://bitbucket.org/appium/appium.app/downloads/ 2. 系统变量PATH 增加 C:\Program Files ...
- 实验四 Android程序设计
20155224 实验四 Android程序设计 实验报告 实验报告封面: 课程:Java程序设计 班级:1652班 姓名:王高源 学号:20165225 指导教师:娄嘉鹏 实验日期:2018年5月1 ...
- load和initialize
load: 当类被引用进项目的时候(类文件加载到系统中)就会执行load函数(在main函数开始执行之前),与这个类是否被用到无关,每个类的load函数只会自动调用一次.由于load函数是系统自动加载 ...
- Vue通过build打包后 打开index.html页面是空白的
最近在build打包vue项目遇到了几个问题,如下: 1.npm run build打包项目之后,我们通常是把dist文件里面被压缩后的static文件跟index.html提交到服务器,但最近发现直 ...
- sql语句优化(一)
1.查看执行时间和cpu占用时间 set statistics time on select * from dbo.Product set statistics time off 2.查看查询对I/0 ...