## 题目大意

一条街道有\(n\)个区域。 从左到右编号为\(1\)到\(n\)。 相邻区域之间的距离为\(1\)。

在节日期间,有\(m\)次烟花要燃放。 第\(i\)次烟花燃放区域为\(a_i\) ,幸福属性为\(b_i\),时间为\(t_i\)。\(t_i \leqslant t_{i+1}\)

如果你在第\(i\)次烟花发射时在\(x(1\leqslant x \leqslant n)\)处,你将获得幸福值\(b_i - | a_i - x |\) (请注意,幸福值可能是负值)。

你可以在单位时间间隔内移动最多\(d\)个单位,但禁止走出主要街道。 此外,您可以在初始时刻(时间等于\(1\)时)处于任意区域,并希望最大化从观看烟花中获得的幸福总和。

输出最大的幸福总和。

题目解答

本题是单调队列优化\(DP\)的经典题目。

设\(dp[i][j]\)表示第\(i\)次烟花燃放时你位于\(j\)处所能获得的最大的幸福总和。

而第\(i-1\)次烟花燃放到第\(i\)次烟花燃放所能移动的最大距离为\(h=(t_i-t_{i-1})*d\)。

所以该次燃放后可能获得的幸福总和由上一次位于\([j-h,j+h]\)处的\(2h+1\)种情形得到。

且\(dp[i][j]=\max\{dp[i-1][k]+b[i]-|a[i]-j|\} \quad k\in [j-h,j+h]\)

即\(dp[i][j]=\max\{dp[i-1][k]\}+b[i]-|a[i]-j| \quad k\in [j-h,j+h]\)

故对于\(j\in[1,n]\) ,要求\(dp[i][j]\)的值只要求解\(dp[i-1]\)数组位于\([j-h,j+h]\)的最大值,而求解这一步可以用单调队列解决,复杂度\(O(n)\),即可求解完\(dp[i]\)数组。

又发现\(dp[i]\)数组的求解只与\(dp[i-1]\)数组有关,故这一维可以滚动处理。

\(dp[s1]\)表示源状态,\(dp[s2]\)表示将求解状态,求解完交换\(s1\),\(s2\)即可。\(s1,s2\in\{0,1\}\)

单调队列处理部分

我的代码采用双端队列\(deque\)处理,较为简洁。

\(deque\)存储位置编号

其中\(deque\)中从队首到队尾,位置编号严格增加,该位置源状态\(dp\)源状态值严格减少;

处理位置\(i\)(采用代码中变量意义)时,将还未处理的小于\(i+h\)的位置依次入队尾(可能有些元素会被赶出队尾,因为它们不可能再被使用到),再将小于\(i-h\)的位置依次出队头。则队首所在位置便是源状态位于\([i-h,i+h]\)的最大值,即可得到现状态。

源代码

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const int maxn=15e4+10;
LL q,m,d,n,s1=0,s2=1;
LL dp[2][maxn];
int main(){
scanf("%lld%lld%lld%",&n,&m,&d);
LL a,b,t,qian_t=1;
while(m--){
scanf("%lld%lld%lld%",&a,&b,&t);
LL h=(t-qian_t)*d;
qian_t=t;
deque<int> qu;
for(int i=1,j=1;i<=n;i++){
for(;j<=i+h&&j<=n;j++){
while(!qu.empty()&&dp[s1][qu.back()]<=dp[s1][j])qu.pop_back();
qu.push_back(j);
}
while(!qu.empty()&&qu.front()<i-h)qu.pop_front();
dp[s2][i]=dp[s1][qu.front()]+b-abs(i-a);
}
swap(s1,s2);
}
LL maxm=dp[s1][1];
for(int i=2;i<=n;i++){
if(dp[s1][i]>maxm)maxm=dp[s1][i];
}
printf("%lld",maxm);
}

结束语

欢迎留言!你们的支持与推荐是博主发展的动力XD.

【简洁易懂】CF372C Watching Fireworks is Fun dp + 单调队列优化 dp优化 ACM codeforces的更多相关文章

  1. 题解-------CF372C Watching Fireworks is Fun

    传送门 一道有趣的DP 题目大意 城镇中有$n$个位置,有$m$个烟花要放.第$i$个烟花放出的时间记为$t_{i}$,放出的位置记为$a_{i}$.如果烟花放出的时候,你处在位置$x$,那么你将收获 ...

  2. [poj3017] Cut the Sequence (DP + 单调队列优化 + 平衡树优化)

    DP + 单调队列优化 + 平衡树 好题 Description Given an integer sequence { an } of length N, you are to cut the se ...

  3. DP+单调队列 codevs 1748 瑰丽华尔兹(还不是很懂具体的代码实现)

    codevs 1748 瑰丽华尔兹 2005年NOI全国竞赛  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 大师 Master 题解       题目描述 Descripti ...

  4. hdu4374One hundred layer (DP+单调队列)

    http://acm.hdu.edu.cn/showproblem.php?pid=4374 去年多校的题 今年才做 不知道这一年都干嘛去了.. DP的思路很好想 dp[i][j] = max(dp[ ...

  5. 习题:烽火传递(DP+单调队列)

    烽火传递[题目描述]烽火台又称烽燧,是重要的防御设施,一般建在险要处或交通要道上.一旦有敌情发生,白天燃烧柴草,通过浓烟表达信息:夜晚燃烧干柴,以火光传递军情.在某两座城市之间有n个烽火台,每个烽火台 ...

  6. BZOJ_1999_[Noip2007]Core树网的核_单调队列+树形DP

    BZOJ_1999_[Noip2007]Core树网的核_单调队列+树形DP Description 设T=(V, E, W) 是一个无圈且连通的无向图(也称为无根树),每条边带有正整数的权,我们称T ...

  7. (noip模拟二十一)【BZOJ2500】幸福的道路-树形DP+单调队列

    Description 小T与小L终于决定走在一起,他们不想浪费在一起的每一分每一秒,所以他们决定每天早上一同晨练来享受在一起的时光. 他们画出了晨练路线的草图,眼尖的小T发现可以用树来描绘这个草图. ...

  8. 3622 假期(DP+单调队列优化)

    3622 假期 时间限制: 1 s 空间限制: 64000 KB 题目等级 : 黄金 Gold 题目描述 Description 经过几个月辛勤的工作,FJ决定让奶牛放假.假期可以在1-N天内任意选择 ...

  9. 【优化】单调队列与dp

    笔者大概看了一下单调队列对于DP的优化,故撰此文,望有帮助. (dp还是推式子难啊qwq) 例题1. 题目大意:在n个数的序列中,选择数字,使得其连续不超过k个数,且和最大. 本题的方程相对好推:设d ...

  10. DP+单调队列详解+题目

    介绍: 单调队列优化的原理   先回顾单调队列的概念,它有以下特征:   (1)单调队列的实现.用双端队列实现,队头和队尾都能插入和弹出.手写双端队列很简单.   (2)单调队列的单调性.队列内的元素 ...

随机推荐

  1. python网络爬虫(11)近期电影票房或热度信息爬取

    目标意义 为了理解动态网站中一些数据如何获取,做一个简单的分析. 说明 思路,原始代码来源于:https://book.douban.com/subject/27061630/. 构造-下载器 构造分 ...

  2. NOIP最后阶段每日小记

    前言:最后几天了,记录一下每天的经验.教训.启示.大牛路过请补充一点内容…… 2017-10-31 21:32 今天考试打完第一题就知道是AK场,然后就死命搞题,结果第一题手贱多打了一个%,本机无显示 ...

  3. HTML表单部分学习笔记

    第一部分: <!-- action :指定处理提交表单的格式 method :指定提交表单的http方法 enctype:指明用来把表单提交给服务器时的互联网媒体形式 --> <fo ...

  4. 【Netty】使用解码器Decoder解决TCP粘包和拆包问题

    解码器Decoder和ChannelHandler的关系 netty的解码器通常是继承自ByteToMessageDecoder,而它又是继承自ChannelInboundHandlerAdapter ...

  5. 算法学习笔记,几个简单的Demo

    算法初学的一些心得 前言:现在工作也快一年多了,有时间下班回家会学学算法,陆陆续续也接触了一些 貌似我知道的就冒泡排序其他的都不是很了解 最近买了一本书,边学边记录吧! 一些常用的方法 暴力破解 下面 ...

  6. 数据结构-二叉树(1)以及前序、中序、后序遍历(python实现)

    上篇文章我们介绍了树的概念,今天我们来介绍一种特殊的树--二叉树,二叉树的应用很广,有很多特性.今天我们一一来为大家介绍. 二叉树 顾名思义,二叉树就是只有两个节点的树,两个节点分别为左节点和右节点, ...

  7. 在springboot中使用swagger2

    1.在springboot中使用swagger的话,首先在pom文件中引入依赖 <!-- https://mvnrepository.com/artifact/io.springfox/spri ...

  8. C#5.0新增功能02 调用方信息

    连载目录    [已更新最新开发文章,点击查看详细] 通过使用调用方信息特性,可获取有关方法的调用方的信息. 可以获取源代码的文件路径.源代码中的行号和调用方的成员名称. 此信息有助于跟踪.调试和创建 ...

  9. C#3.0新增功能01 自动实现的属性

    连载目录    [已更新最新开发文章,点击查看详细] 在 C# 3.0 及更高版本,当属性访问器中不需要任何其他逻辑时,自动实现的属性会使属性声明更加简洁. 它们还允许客户端代码创建对象. 当你声明以 ...

  10. PHP中的$_POST变量

    定义 在 PHP 中,预定义的 $_POST 变量用于收集来自 method="post" 的表单中的值. $_POST 变量 预定义的 $_POST 变量用于收集来自method ...