相信很多小伙伴刷题的时候面对力扣上近两千到题目,感觉无从下手,我花费半年把力扣上经典题目的做题顺序都整理出来了,发布在Github上:leetcode刷题指南,不仅有详细经典题目刷题顺序而且对应题解都排好了,难点还有视频讲解,按照list一道一道刷就可以了,绝对是最强刷题攻略!

这周我们正式开始动态规划的学习!

周一

在关于动态规划,你该了解这些!中我们讲解了动态规划的基础知识。

首先讲一下动规和贪心的区别,其实大家不用太强调理论上的区别,做做题,就感受出来了。

然后我们讲了动规的五部曲:

  1. 确定dp数组(dp table)以及下标的含义
  2. 确定递推公式
  3. dp数组如何初始化
  4. 确定遍历顺序
  5. 举例推导dp数组

后序我们在讲解动规的题目时候,都离不开这五步!

本周都是简单题目,大家可能会感觉 按照这五部来好麻烦,凭感觉随手一写,直接就过,越到后面越会感觉,凭感觉这个事还是不靠谱的,哈哈。

最后我们讲了动态规划题目应该如何debug,相信一些录友做动规的题目,一旦报错也是凭感觉来改。

其实只要把dp数组打印出来,哪里有问题一目了然!

如果代码写出来了,一直AC不了,灵魂三问:

  1. 这道题目我举例推导状态转移公式了么?
  2. 我打印dp数组的日志了么?
  3. 打印出来了dp数组和我想的一样么?

哈哈,专治各种代码写出来了但AC不了的疑难杂症。

周二

这道题目动态规划:斐波那契数是当之无愧的动规入门题。

简单题,我们就是用来了解方法论的,用动规五部曲走一遍,题目其实已经把递推公式,和dp数组如何初始化都给我们了。

周三

动态规划:爬楼梯 这道题目其实就是斐波那契数列。

但正常思考过程应该是推导完递推公式之后,发现这是斐波那契,而不是上来就知道这是斐波那契。

在这道题目的第三步,确认dp数组如何初始化,其实就可以看出来,对dp[i]定义理解的深度。

dp[0]其实就是一个无意义的存在,不用去初始化dp[0]。

有的题解是把dp[0]初始化为1,然后遍历的时候i从2开始遍历,这样是可以解题的,然后强行解释一波dp[0]应该等于1的含义。

一个严谨的思考过程,应该是初始化dp[1] = 1,dp[2] = 2,然后i从3开始遍历,代码如下:

dp[1] = 1;
dp[2] = 2;
for (int i = 3; i <= n; i++) { // 注意i是从3开始的dp[i] = dp[i - 1] + dp[i - 2];
}

这个可以是面试的一个小问题,哈哈,考察候选人对dp[i]定义的理解程度。

这道题目还可以继续深化,就是一步一个台阶,两个台阶,三个台阶,直到 m个台阶,有多少种方法爬到n阶楼顶。

这又有难度了,这其实是一个完全背包问题,但力扣上没有这种题目,所以后续我在讲解背包问题的时候,今天这道题还会拿从背包问题的角度上来再讲一遍。

这里我先给出我的实现代码:

class Solution {
public:int climbStairs(int n) {vector<int> dp(n + 1, 0);dp[0] = 1;for (int i = 1; i <= n; i++) {for (int j = 1; j <= m; j++) { // 把m换成2,就可以AC爬楼梯这道题if (i - j >= 0) dp[i] += dp[i - j];}}return dp[n];}
};

代码中m表示最多可以爬m个台阶。

以上代码不能运行哈,我主要是为了体现只要把m换成2,粘过去,就可以AC爬楼梯这道题,不信你就粘一下试试,哈哈

此时我就发现一个绝佳的大厂面试题,第一道题就是单纯的爬楼梯,然后看候选人的代码实现,如果把dp[0]的定义成1了,就可以发难了,为什么dp[0]一定要初始化为1,此时可能候选人就要强行给dp[0]应该是1找各种理由。那这就是一个考察点了,对dp[i]的定义理解的不深入。

然后可以继续发难,如果一步一个台阶,两个台阶,三个台阶,直到 m个台阶,有多少种方法爬到n阶楼顶。这道题目leetcode上并没有原题,绝对是考察候选人算法能力的绝佳好题。

这一连套问下来,候选人算法能力如何,面试官心里就有数了。

其实大厂面试最喜欢问题的就是这种简单题,然后慢慢变化,在小细节上考察候选人

这道绝佳的面试题我没有用过,如果录友们有面试别人的需求,就把这个套路拿去吧,哈哈哈。

我在通过一道面试题目,讲一讲递归算法的时间复杂度!中,以我自己面试别人的真实经历,通过求x的n次方 这么简单的题目,就可以考察候选人对算法性能以及递归的理解深度,录友们可以看看,绝对有收获!

周四

这道题目动态规划:使用最小花费爬楼梯就是在爬台阶的基础上加了一个花费,

这道题描述也确实有点魔幻。

题目描述为:每当你爬上一个阶梯你都要花费对应的体力值,一旦支付了相应的体力值,你就可以选择向上爬一个阶梯或者爬两个阶梯。

示例1:

输入:cost = [10, 15, 20]
输出:15

从题目描述可以看出:要不是第一步不需要花费体力,要不就是第最后一步不需要花费体力,我个人理解:题意说的其实是第一步是要支付费用的!。因为是当你爬上一个台阶就要花费对应的体力值!

所以我定义的dp[i]意思是也是第一步是要花费体力的,最后一步不用花费体力了,因为已经支付了。

之后一些录友在留言区说 可以定义dp[i]为:第一步是不花费体力,最后一步是花费体力的。

所以代码也可以这么写:

class Solution {
public:int minCostClimbingStairs(vector<int>& cost) {vector<int> dp(cost.size() + 1);dp[0] = 0; // 默认第一步都是不花费体力的dp[1] = 0;for (int i = 2; i <= cost.size(); i++) {dp[i] = min(dp[i - 1] + cost[i - 1], dp[i - 2] + cost[i - 2]);}return dp[cost.size()];}
};

这么写看上去比较顺,但是就是感觉和题目描述的不太符。哈哈,也没有必要这么细扣题意了,大家只要知道,题目的意思反正就是要不是第一步不花费,要不是最后一步不花费,都可以。

总结

本周题目简单一些,也非常合适初学者来练练手。

下周开始上难度了哈,然后大下周就开始讲解背包问题,好戏还在后面,录友们跟上哈。

学算法,认准「代码随想录」就够了,Carl带你打怪升级!

我是程序员Carl,可以找我组队刷题,也可以在B站上找到我,关注公众号代码随想录来和上万录友一起打卡学习算法,来看看,你会发现相见恨晚!

如果感觉对你有帮助,不要吝啬给一个

「代码随想录」本周小结!(动态规划系列一)相关推荐

  1. 「代码家」的学习过程和学习经验分享【转】

    图灵丛书的一句话说的很好,Standing on the shoulders of giants,是的,我们一直站在巨人的肩上,我们起步都在沿着他们的轨迹前行,之后慢慢的在前人的开发基础或者规范上写出 ...

  2. 新功能又来啦!这次是「代码搜索」和视频直播!

    不知不觉又到周五,菌菌又带着新功能来啦! 代码搜索功能发布,提升开发效率 开发一个项目,配置参数是必不可少的步骤,而项目规模越大需要配置的参数就越多.怎么样?是不是已经开始头疼了?dengdengde ...

  3. 如何排版 微信公众号「代码块」之 MarkEditor

    前段时间写过一篇文章 如何排版微信公众号「代码块」,讲的是如何使用浏览器插件 Markdown Here 来排版代码块.虽然用 Markdown Here 排版出来的样式还不错,但存在一个问题,就是代 ...

  4. 如何排版 微信公众号「代码块」

    最近博主刚开通微信公众号「石佳劼的博客」,被微信公众平台的图文编辑器折腾的不轻,如果文章中包含「代码块」,怎么排版都显得杂乱无章.之前一直用 Markdown 写作,从来没有考虑过排版.样式问题,因为 ...

  5. 代码随想录python笔记9 动态规划

    理论基础 动态规划 动态规划,英文:Dynamic Programming,简称DP,如果某一问题有很多重叠子问题,使用动态规划是最有效的. 和贪心的区别 所以动态规划中每一个状态一定是由上一个状态推 ...

  6. “高定美学”品牌矩阵:「莲玉芳华」「琢我」「佐我」佐我气运系列之进击

    WinderRoad稳略全球家族办公室旗下的中国式高阶生活美学代表: FinRise奋睿资本的 "高定美学"品牌矩阵内「莲玉芳华」「琢我」「佐我」又在海内外塑造中国式美学新形象与帮 ...

  7. 【代码随想录】二刷-动态规划

    动态规划 代码随想录 解题步骤: 确定dp数组 确定递推公式--递推公式决定dp数组要如何初始化 dp数组如何初始化 确定遍历顺序 举例推导dp数组 509. 斐波那契数 class Solution ...

  8. 代码随想录算法训练营Day56动态规划:583.两个字符串的删除操作,72.编辑距离

    583.两个字符串的删除操作 文章链接:代码随想录 (programmercarl.com) 思路:动规五步曲 (1)确定dp数组及其含义 dp[i][j]表示字符串1在区间[0, i - 1]和字符 ...

  9. c语言动态规划回溯的原理,「算法思想」分治、动态规划、回溯、贪心一锅炖...

    观感度:????? 口味:东北一锅出 烹饪时间:10min 本文已收录在Github github.com/Geekhyt,感谢Star. 数据结构与算法系列专栏第四弹来袭,往期专栏链接如下: 初学者 ...

  10. 「代码家」的学习过程和学习经验分享

    每天,都会有人在微博上私信我,问我关于学习和成长的问题.这种问题我一般都不会回复某个j,毕竟每个人的情况不一样,每个人对待事物的性格也不一样,我不能夸下海口的说,你看某本书几个月就能如何如何,我能做的 ...

最新文章

  1. extern数组与extern指针
  2. 浅谈.Net WebService开发
  3. linux显卡驱动未加载,Linux下无显卡驱动的解决办法
  4. cve-2014-7911安卓提权漏洞分析
  5. extjs 在textfield后面加一个button_用python 做一个简单的MP3
  6. 《视觉开发专题》之 OpenGL 概述
  7. C++笔记----运算符重载
  8. 一级计算机办公软件,计算机一级与高级办公软件
  9. BCH码(BCH code)详细分析
  10. 海外邮件收发阻碍多?网易企业邮箱为您保驾护航【网易企业邮箱怎么申请】
  11. npm install 安装一直报错Error EPERM operation not permitted, mkdir
  12. 基于pion生态的SFU实时音视频发布服务(一)
  13. 配准带尺度点云的方法汇总
  14. Unity程序框架总结归置系列(2)——对象池
  15. PMP第八节:项目质量管理
  16. Android应用程序签名 debug签名
  17. 推广海报你需要注意的几个小细节
  18. 近几年比较火的团队协作、项目管理工具测评及工具选择原则介绍
  19. Java死锁产生的四个条件
  20. NextCloud安装使用心得记录

热门文章

  1. 8th 本周工作量及进度统计
  2. mongo(删除操作)
  3. C-Sharp网络编程案例解析(Socket类的使用)
  4. android 输入法出现挤压屏幕、android输入键盘覆盖了屏幕控件的解决办法
  5. 程序员编程艺术第十六~第二十章:全排列,跳台阶,奇偶调序等问题
  6. asp.net core中的razor页面
  7. centos 7 redis-4.0.11 主从
  8. LintCode 137. 克隆图
  9. 更新.xsd后,rdlc 数据源更新不了
  10. iOS:类似于网易云音乐的刷新条目显示弹框