leetcode算法刷题(二)——动态规划(一)
上次刷了五六道题,都是关于string
处理的,这次想换个知识点刷一下,然后再回头刷string的题,当做复习..
这几天主要会选择动态规划的题目,因为以前从没刷过这方面的东西,很多东西都不是很懂..就当重新学习吧~
第198题 House Robber
题目的意思:一个抢劫者要抢劫一条街上的住户,由于每家都有报警器,连续抢劫2家就会触发报警器。现在给你一个列表,里面的元素是每家可抢劫的金额,要求在不触发报警器的情况下抢劫最多的钱
分析:这是一道典型的动态规划题,我们先分析一下。
对于每一家,抢劫者的选择有两个:抢劫或者不抢劫。根据要求我们可以知道,不能连续抢劫2家。假设d(N)是抢劫犯抢劫到第N家的最大金额。当抢劫者抢劫第N家的时候,有两种情况:
- 抢劫第N家,这时候d(N)=nums[N]+d(N-1),而且我们可以知道,第N-1家不能抢劫
- 不抢劫第N家,这时候d(N)=d(N-1)
所以我们可以得到:d(N) = max(nums[N] + d(N-1), d(N-1)). 下面是解法:
class Solution:
# @param {integer[]} nums
# @return {integer}
def rob(self, nums):
noRobN = 0 (不抢劫第N家)
robN = 0 (抢劫第N家)
maxProfix = 0 (最大金额)
for i in range(len(nums)):
robN = nums[N] + noRobN
noRobN = maxProfix
maxProfix = max(robN, noRobN)
return maxProfix
第70题 Climbing Stairs
题目的意思:上楼要爬n级台阶,每次爬台阶有两种爬法:1. 爬一级台阶 2. 爬二级台阶。现在要求爬n级台阶一共有多少种爬法
分析:假设d(n)是爬第n级台阶的时候的爬法个数。当要爬n级台阶的时候,有两种情况:
- 从第n-1级台阶爬一级
- 从第n-2级台阶爬两级
所以我们可以得到:d(n) = d(n-1) + d(n-2),下面是解法:
class Solution:
# @param {integer[]} nums
# @return {integer}
def climbStairs(self, n):
step = 0
onestep = 1
twostep = 0
for i in range(n):
step = onestep + twostep
twostep = onestep
onestep = step
return step
第120题 Triangle
题目的意思:给予一个由多个数列组成的三角形,找出从顶端到底层的最短路径,上层的数字只能移动到下层中与之相邻的数字上。例如:
[
[2],
[3,4],
[6,5,7],
[4,1,8,3]
]
最短路径和 = 2+3+5+1 = 11
分析:这道题不能直接找每行数列的最小值然后相加就和. 这道题的思路是把下层的数依次与上层的数相加(取相邻上层的两个数中的较小的那个),然后取最小,直到最底层。
class Solution:
# @param triangle, a list of lists of integers
# @return an integer
def minimumTotal(self, tr):
#特殊情况,只有一行
if len(tr) == 1:
return tr[0][0]
for i in range(1, len(tr)): #从第二行开始
for j in range(len(tr[i])):
if j == 0: #第一个数
tr[i][j] = tr[i-1][j] + tr[i][j]
elif j == len(tr[i]) -1: #最后一个数
tr[i][j] = tr[i][j] + tr[i-1][j-1]
else: #一般情况
tr[i][j] = min(tr[i-1][j-1], tr[i-1][j]) + tr[i][j]
return min(tr[len(tr)-1])
延伸一下,如果需要输出路径,也很简单,最开始我们新建一个列表,比如li = []
,然后每当取到每行的最小值的时候,就把这个数推入列表中,最后输出列表即可
第64题 Minimum Path Sum
题目的意思:给予一个m * n 的表格grid,表格里面填充了数字,求从grid[0][0]到grid[m-1][n-1]的最小和路径。每次移动只能向下或向右
分析:这道题和上一道基本一样,思路就是MPS[i][j] = Min(MPS[i-1][j],MPS[i][j-1])+ val[i][j]
class Solution:
# @param {integer[][]} grid
# @return {integer}
def minPathSum(self, grid):
row = len(grid) #行
col = len(grid[0]) #列
for i in range(row):
for j in range(col):
if i == 0 and j ==0:
pass
elif i == 0 and j != 0: #最上面一行
grid[i][j] = grid[i][j] + grid[i][j-1]
elif j == 0 and i != 0: #最左边一列
grid[i][j] = grid[i][j] + grid[i-1][j]
else:
grid[i][j] = grid[i][j] + min(grid[i][j-1], grid[i-1][j])
return grid[row-1][col-1]
leetcode算法刷题(二)——动态规划(一)的更多相关文章
- leetcode算法刷题(四)——动态规划(二)
又到了晚上,动态规划,开刷! 第121题 Best Time to Buy and Sell Stock 题目的意思:给予一个数组price,表示特定股票在某天的股价,里面第i个数表示第i天的价格.只 ...
- leetcode算法刷题(五)——动态规划(三)
今天的题目不是leetcode上面的.只是觉得动态规划还是不算很熟练,就接着找了点DP的题练练 最长递增子序列的长度 题目的意思:传入一个数组,要求出它的最长递增子序列的长度.例如:如在序列1,-1, ...
- leetcode 算法刷题(一)
今天开始刷Leetcode上面的算法题.我会更新我刷题过程中提交的代码(成功和不成功的都有)和比较好的解法 第二题 Add Two Numbers 题目的意思:输入两个链表,这两个链表都是倒序的数字, ...
- leetcode算法刷题(三)
今天在刷了几道简单的动态规划后,又看了看string方面的题 第五题 Longest Palindromic Substring 题目的意思:求一个字符串的最长回文子串 分析:开始,我的想法是,现在字 ...
- Leetcode算法刷题:217和219题 Contains Duplicate
从题目名字就可以看出这两道题是相似的,219是217的加强版 217:Contains Duplicate 题目 给予一个数组,判断是否有重复的元素.如果有就返回True,没有就返回False.以下是 ...
- Leetcode算法刷题:第100题 Same Tree
Same Tree 题目 给予两棵二叉树,判断这两棵树是否相等(即各节点的值都一样) 解题思路 分别遍历两棵二叉树,并用列表分别存储这两棵树的节点的值,比较这两个列表就可以了 class Soluti ...
- Leetcode算法刷题:第14题 Longest Common Prefix
Longest Common Prefix 题目 给予一个列表,元素为字符串,写一个程序找出最长公共前缀 解题思路 先比较两个字符串,如果第一个字符不一样,则返回空值,比较完成后,用这个公共字符串和下 ...
- Leetcode算法刷题:第112题 Path Sum
Path Sum 题目 给予一个二叉树,和一个值su,寻找是否有一个从根节点到叶节点的和为su,有则返回True,没有为False.比如: 5 / \ 4 8 / / \ 11 13 4 / \ \ ...
- leetcode top-100-liked-questions刷题总结
一.起因 宅在家中,不知该做点什么.没有很好的想法,自己一直想提升技能,语言基础自不必言,数据结构还算熟悉,算法能力一般.于是乎,就去刷一通题. 刷题平台有很多,我选择了在leetcode进行刷题.回 ...
随机推荐
- 【Android 错误记录】android.os.NetworkOnMainThreadException 异常问题
最近自己学习开发一个小app,想根据网络来判断一些逻辑,但是运行应用时遇到了这个错误 android.os.NetworkOnMainThreadException 后来,查询了一些信息,发现原因就是 ...
- 【转】mysql行列转换方法总结
转:http://blog.chinaunix.net/uid-7692530-id-2567582.html 在某些数据库中有交叉表,但在MySQL中却没有这个功能,但网上看到有不少朋友想找出一个解 ...
- nginx+webpy 出现 upstream timed out
关于nginx配置webpy应用出现的错误 upstream timed out (: Connection timed out) while reading response header from ...
- php的DOMDocument 如何判断xml是否存在某节点
在做xml解释时,需要判断是否存在某个节点,查了手册函数,硬是没有发现那个函数有这个功能(如果你知道的话,请留言,博主感激涕零). 下面,就说下博主,经过N多博文,论坛查阅后,得到的一种方法(看到的博 ...
- java学习一目了然——异常必知
java学习一目了然--异常必知 我们只要学java,异常肯定非常熟悉,该抛的时候抛一下就行.但是这其中还有点小细节需要注意.就用这个小短篇来说一下异常处理中的小细节吧. 异常处理 RuntimeEx ...
- python核心编程-第五章-习题
1.长整型表示数的范围比整型更大.在python中,整型.长整型趋于统一,普通用户不用特别关注两者区别,仅当需引用C语言时需要特别注意. 2.操作符 (a) def product(x,y): ret ...
- FatMouse' Trade(hdoj1009)
Problem Description FatMouse prepared M pounds of cat food, ready to trade with the cats guarding th ...
- Elevator(hdoj 1008)
Problem Description The highest building in our city has only one elevator. A request list is made u ...
- MySQLBackup 使用说明
001.mysqlbackup介绍: mysqlbackup是一个热备份工具.也就是说它不像mysqldump那样给表上一个全局锁,由于mysqldump上了这个锁,所以就造成客户端只能对 数据库进行 ...
- 【深夜急报,Win10下的Linux子系统之Bash】
[在Windows下进行的编程人员,你真的需要学习下Linux] 手册:<Linux 命令手册(特洛伊版2.0)> 链接: https://pan.baidu.com/s/1skrVSvV ...