序列 DP
admin
2024-02-24 03:28:04
0

文章目录

  • [813. 最大平均值和的分组](https://leetcode.cn/problems/largest-sum-of-averages/)
  • [1478. 安排邮筒](https://leetcode.cn/problems/allocate-mailboxes/)
  • [2463. 最小移动总距离](https://leetcode.cn/problems/minimum-total-distance-traveled/)

813. 最大平均值和的分组

dp[i][j] 表示 nums 在区间 [0,i) 被切分成 j 个子数组的最大平均值和,显然 i ≥ j,计算分两种情况讨论:

当 j = 1 时,dp[i][j] 是对应区间 [0, i) 的平均值;
当 j > 1 时,可以将区间 [0, i - 1] 分成 [0, x) 和 [x, i ) 两个部分,其中 x > j,那么 dp[i][j] 等于所有这些合法的切分方式的平均值和的最大值。

因此转移方程为:

dp[i][j]={∑r=0i−1nums[r]i,j=1max⁡x≥j−1{dp[x][j−1]+∑r=xi−1nums[r]i−x},j>1\textit{dp}[i][j] = \begin{cases} \dfrac{\sum_{r = 0}^{i - 1}\textit{nums}[r]}{i}, & j = 1 \\ \max\limits_{x \ge j - 1} \{dp[x][j - 1] + \dfrac{\sum_{r = x}^{i - 1}\textit{nums}[r]}{i - x}\}, & j > 1 \end{cases}dp[i][j]=⎩⎪⎪⎨⎪⎪⎧​i∑r=0i−1​nums[r]​,x≥j−1max​{dp[x][j−1]+i−x∑r=xi−1​nums[r]​},​j=1j>1​

假设数组 nums 的长度为 n,那么 dp[n][k] 表示数组 nums 分成 k 个子数组后的最大平均值和,即最大分数。

class Solution:def largestSumOfAverages(self, nums: List[int], k: int) -> float:n = len(nums)acc = list(accumulate(nums, initial=0))dp = [[0.0] * (k + 1) for _ in range(n + 1)]for i in range(1, n + 1):dp[i][1] = acc[i] / ifor j in range(2, k + 1):for i in range(j, n + 1):for x in range(j - 1, i):dp[i][j] = max(dp[i][j], dp[x][j - 1] + (acc[i] - acc[x]) / (i - x))return dp[n][k]

由于 dp[i][j] 的计算只利用到 j−1 的数据,因此也可以使用一维数组对 dp[i][j] 进行计算,在计算过程中,要注意对 i 进行逆序遍历。

class Solution:def largestSumOfAverages(self, nums: List[int], k: int) -> float:n = len(nums)prefix = list(accumulate(nums, initial=0))dp = [0.0] * (n + 1)for i in range(1, n + 1):dp[i] = prefix[i] / ifor j in range(2, k + 1):for i in range(n, j - 1, -1):for x in range(j - 1, i):dp[i] = max(dp[i], dp[x] + (prefix[i] - prefix[x]) / (i - x))return dp[n]

动态规划,1478题、最近周赛的2463题都是类似的题目,属于把一个数组分成k段求一个最值属性。套路比较统一,dp[i][k]表示将nums[0:i]分成k份的最大平均值和。枚举一个能使dp[i][k]取最大值的分割点j,0j分成k-1份,j+1i单独一份。一般j+1~i段的那个属性可以利用某些预处理在常数时间得到,本题只需要预处理出来前缀和就能快速计算子数组的平均值。

const int N = 110;
double dp[N][N];class Solution {
public:double largestSumOfAverages(vector& nums, int K) {int n = nums.size();memset(dp, 0, sizeof dp);vector s(n);s[0] = nums[0];for(int i = 1; i < n; i++) {s[i] = s[i - 1] + nums[i];}for(int i = 0; i < n; i++) dp[i][1] = s[i]*1.0 / (i + 1);for(int i = 1; i < n; i++) {for(int k = 2; k <= min(i + 1, K); k++) {for(int j = 0; j < i; j++) {dp[i][k] = max(dp[i][k], dp[j][k - 1] + windowSum(s, j + 1, i)/(i - j));}}}double ans = 0;for(int k = 1; k <= K; k++) ans = max(ans, dp[n - 1][k]);return ans;}double windowSum(vector& s, int left, int right) {return s[right] - (left? s[left - 1]: 0);}
};

1478. 安排邮筒

2463. 最小移动总距离

相关内容

热门资讯

土耳其BIST-100指数下跌... 土耳其BIST-100指数下跌1.8%,主要银行指数下跌2.4%。 来源:金融界AI电报
15分钟动态电价时代:园区光伏... 一、电价改革的“加速度”:从分时计费到现货波动 过去,工商业用户的电价表一年可能只调整几次,峰、平、...
湘潭上元产业港:多套成交 12... 湘潭上元产业港再迎成交热潮,近期3套优质厂房成功签约,多位企业家携手落子,以实力见证长株潭热土的产业...
4月新增人民币贷款跌入负区间,... 本报(chinatimes.net.cn)记者刘佳 北京报道 作为观察货币政策传导效率的核心窗口,4...
2.2/7.2馆展位图首发!5... 【2.2馆展位图】 【7.2馆展位图】 Bakery china 2.2馆部分 企业推介 22B...
如何以互联网赋能家风传承 家庭是社会的细胞。家庭和睦则社会安定,家庭幸福则社会祥和,家庭文明则社会文明。历史和现实告诉我们,家...
跌势升级!5月15日国内金店金... 今日国内品牌金店黄金价格跌势再次升级,主流品牌报价已全线回落至1402-1412元/克区间。老凤祥以...
估值冰点与业绩高增的背离难以持... 来源:新浪基金 5月15日,券商板块延续连日来的回调态势,规模369亿元+的顶流券商ETF华宝(51...
欢迎晚宴上坐在马斯克和库克中间... 【CNMO科技消息】据CNMO科技了解,在5月14日晚为美国总统特朗普访华举行的欢迎宴会上,一张特殊...
公司的歌尔微港股上市能否加速推... 有投资者向歌尔股份(002241.SZ)提问,请董秘先生详细讲解一下公司的MEMS传感器布局,在面对...
原创 目... 当地时间5月14日,俄军发动大规模空袭行动,将打击重点直指乌克兰境内的炼油厂及相关能源设施,此举直接...
A股探底回升,沪指半日上涨0.... 每经记者|刘明涛 每经编辑|彭水萍 5月15日,A股探底回升,截至上午收盘,上证指数涨0.12%报...
茅台是用来喝的不是拿来炒的,金... 作者:道传 出品:锐见深解读 当一瓶酒的价格曲线开始比消费曲线更受关注时,它就已经偏离了“商品”的本...
原创 探... 昨天是尾盘直接崩掉了,下跌还放量,今天则是探底回升,大A终于看懂时事。 有评论说老特是非常聪明的,他...
越品越香的大窑20香,正在打造... 当下饮品行业步入竞争新阶段,而作为最重要的场景之一,餐桌消费对饮品的专属感与层次感诉求正在持续攀升。...
达实面向滇西多民族及边疆地区,... 大理白族自治州人民医院旨在打造环境一流、技术一流、设备一流、管理一流、服务一流的滇西医疗中心龙头医院...
兴业银行东莞分行正式获批公积金... 近日,兴业银行东莞分行正式获批住房公积金归集业务办理资格,社保卡业务也全面上线。两项民生金融业务的同...
“最大AI芯片”公司上市首日涨... 美股5月14日,多只AI芯片股走高。英伟达(NVDA.O)涨4.39%,市值5.7万亿美元,创历史新...
刚刚,史上最大AI芯片IPO了... 芯东西(公众号:aichip001) 作者 | ZeR0 编辑 | 漠影 芯东西5月15日报道,今日...