区间DP

第一类:

给出⼀个序列,明确要求分割成K个连续区间,要求我们计算这些区间的某个最有性质

题目813:将数组nums 分成 最多k个非空子数组,使得数组平均值的总和最大。

思路:

dp[i][j]:数组nums[:i+1] 切 j-1刀得到的最大平均值总和。初始化为负无穷。

递推公式:dp[i][j] = max(dp[i][j], dp[l][j - 1] + (sub_sums[i+1] - sub_sums[l+1])/(i-l)),dp[i][j]由少切一刀的dp[l][j - 1]和区间nums[l+1:i+1]共同决定。

遍历顺序:数组结尾 i 外层循环。刀j内层。多一刀的分割点 l [j-1, i-1]。正序遍历。 

题目1278:给定字符串s和整数k。把s分割成k个子串,每个子串都是回文。(可以修改部分字符)返回最少的修改数。

思路:

dp[i][j]:字符串s[:i+1] 切 j-1刀得到回文子串的最少修改数。初始化为正无穷。

递推公式:dp[i][j] = min(dp[i][j], dp[l][j-1] + self.to_pld(s[l:i])),dp[i][j]由少切一刀的dp[l][j - 1]和区间 s[l:i]共同决定。

遍历顺序:数组结尾 i 外层循环。刀j内层。多一刀的分割点 l [j, i]。正序遍历。 

题目410:给定一个非负整数数组 nums 和整数k ,将这个数组分成k 个非空的连续子数组。使得这子数组和的最大值最小。

思路:

dp[i][j]:数组 nums[:i+1] 切 j-1刀得到的子数组,数组和的最大值的最小值。初始化为正无穷。

递推公式:dp[i][j] = min(dp[i][j], max(dp[l][j-1], sub_sum[i] - sub_sum[l])),dp[i][j]由少切一刀的dp[l][j - 1]和区间 s[l:i]共同决定。

遍历顺序:数组结尾 i 外层循环。刀j内层。多一刀的分割点 l [j, i]。正序遍历。 

题目1335:给定一个工作难度jobDifficulty和工作天数d,工作必须按顺序进行,且每天至少完成一项任务。制定一份d天的工作计划表,使得难度最小。工作计划的总难度是这d天的难度之和,而一天的工作难度是当天应该完成工作的最大难度。

思路:其实就是切成d个子数组,子数组最大值的和最小。

dp[i][j]:数组 jobDifficulty[:i+1] 切 j-1刀得到的子数组,数组最大值的和的最小值。初始化为正无穷。

递推公式:dp[i][j] = min(dp[i][j], dp[l][j-1] + max(jobDifficulty[l:i])),dp[i][j]由少切一刀的dp[l][j - 1]和区间 jobDifficulty[l:i]共同决定。

遍历顺序:数组结尾 i 外层循环。刀j内层。多一刀的分割点 l [j, i]。正序遍历。 

第二类

题目664:奇怪的打印机:每次只能打印由 同一个字符 组成的序列。每次打印会覆盖掉原来已有的字符。计算打印机打印 s 需要的最少打印次数。

思路:

dp[i][j]:s[i: j+1]的最少打印次数。初始化为正无穷大。由于是从中间往两边拓展的,就先把对角线的元素填为1.

递推公式:如果 s[i] == s[j],dp[i][j] = dp[i][j-1];否则就要遍历 for k in range(i, j): dp[i][j] = min(dp[i][j], dp[i][k] + dp[k+1][j])

遍历顺序:只要填上三角的元素,行从下往上,列从左往右。

题目1547:给定长度为 n 个单位的木棍和数组 cuts ,其中 cuts[i] 表示你需要将棍子切开的位置。每次切割的成本都是当前要切割的棍子的长度,返回切棍子的 最小总成本 。

思路:dp[i][j]:木棍[i: j+1]的切割总成本。初始化为正无穷大。

递推公式:对于木棍内部[i: j+1]的每一个可能切割点k: dp[i][j] = min(dp[i][j], cuts[j]-cuts[i] + dp[i][l] + dp[l][j])。如果遍历后还是inf,就等于0

遍历顺序:只要填上三角的元素,行从下往上,列从左往右。

题目1690:有 n 块石子排成一排 stones 。两个玩家在其回合中,可以从行中 移除 最左边的石头或最右边的石头,并获得剩余石头值之 和 作为得分。请返回两个玩家 得分的差值 。

思路:dp[i][j]:面对stones[i:j+1],先手玩家可以得到的最大得分差。初始化为0.

递推公式:先手玩家面临取左边还是取右边的抉择。dp[i][j] = max(sub_sum[j+1] - sub_sum[i+1] - dp[i+1][j], sub_sum[j] - sub_sum[i] - dp[i][j-1])

遍历顺序:只要填上三角的元素,行从下往上,列从左往右。

题目1745:给你一个字符串 s ,如果可以将它分割成三个 非空 回文子字符串,那么返回 true ,否则返回 false 。

思路:先做出回文子串的dp方阵。dp[i][j] 代表s[i:j+1]为回文子串。然后用遍历i, j 两个切割点,看能否分成三个回文子串。

题目1000:有 n 堆石头,第 i 堆中有stones[i]块石头。每次将相邻的 k 堆石头合并为一堆,成本为这 k 堆中石头的总数。返回把所有石头合并成一堆的最低成本。

思路:dp[i][j]:将 i 到 j 的石头堆合并的成本。初始化为inf,对于每个k堆连续石头,可以先合并。dp[i][i+k-1] = sub_sum[i+k] - sub_sum[i]

递推公式:对于for l in range(i+k-1, j, k-1): dp[i][j] = min(dp[i][j], dp[i][l] + dp[l+1][j])

遍历顺序:只要填上三角的元素,行从下往上,列从左往右。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,837评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,551评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,417评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,448评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,524评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,554评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,569评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,316评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,766评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,077评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,240评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,912评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,560评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,176评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,425评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,114评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,114评论 2 352

推荐阅读更多精彩内容