浅谈单调队列优化dp

单调队列,即单调的队列。有时用于优化1D/1D方程。


例题 Tyvj1305

时间: 1000ms / 空间: 131072KiB / Java类名: Main

描述

输入一个长度为n的整数序列,从中找出一段不超过M的连续子序列,使得整个序列的和最大。
例如

1,-3,5,1,-2,3
当m=4时,S=5+1-2+3=7
当m=2或m=3时,S=5+1=6  
输入格式
  • 第一行两个数n,m
  • 第二行有n个数,要求在n个数找到最大子序和
输出格式
  • 一个数,数出他们的最大子序和
测试样例
输入
6 4 
1 -3 5 1 -2 3
输出
7
备注

数据范围:
100%满足n,m<=300000

分析

这是一个典型的动态规划题目,不难得出一个1D/1D方程:

f(i) = sum[i]-min{
  sum[k]|i-M≤k≤i} 

如果不明白这个方程的来历,戳这里

由于方程是1D/1D的,所以我们不想只得出简单的Θ(n^2)算法。不难发现,此优化的难点是计算min{sum[i-M]..sum[i-1]}。在上面的链接中,我们成功的用Θ(nlgn)的算法解

  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值