Vijos1834 NOI2005 瑰丽华尔兹 动态规划 单调双端队列优化
设dp[t][x][y]表示处理完前t个时间段,钢琴停留在(x,y)处,最多可以走多少个格子
转移时只需逆着当前倾斜的方向统计len个格子(len为时间区间的长度,len=t-s+1),如果遇到障碍就中断
转移过程可以用单调非递增的双端队列优化
#include <cstdio> #include <cstring> #include <algorithm> ; const int inf=0x3f3f3f3f; ][maxN][maxN]; char map[maxN][maxN]; int deqv[maxN]; int deqn[maxN]; int head,tail; int N,M,x,y,K; inline void resetDeq() { head=-; tail=; } inline void popDeq(int n,int len) { if(tail<head && n-deqn[tail]>len) ++tail; } inline void pushDeq(int v,int n) { while(head>=tail && v>deqv[head]) --head; deqv[++head]=v; deqn[head]=n; } inline int maxDeq() { if(head>=tail) return deqv[tail]; else return -inf; } int main() { scanf("%d%d%d%d%d",&N,&M,&x,&y,&K); ;i<=N;i++) scanf(); memset(dp,0xc0,sizeof(dp)); dp[][x][y]=; int s,t,dir; int len; while(K--) { scanf("%d%d%d",&s,&t,&dir); len=t-s+; ) ;i<=N;i++) { resetDeq(); ;j<=M;j++) { if(map[i][j]=='.') { popDeq(j,len); dp[][i][j]=std::max(dp[][i][j],maxDeq()+j); pushDeq(dp[][i][j]-j,j); } ][i][j]=-inf; } } } ) ;i<=N;i++) { resetDeq(); for(int j=M;j;j--) { if(map[i][j]=='.') { popDeq(M-j,len); dp[][i][j]=std::max(dp[][i][j],maxDeq()+M-j); pushDeq(dp[][i][j]-M+j,M-j); } ][i][j]=-inf; } } } ) ;j<=M;j++) { resetDeq(); ;i<=N;i++) { if(map[i][j]=='.') { popDeq(i,len); dp[][i][j]=std::max(dp[][i][j],maxDeq()+i); pushDeq(dp[][i][j]-i,i); } ][i][j]=-inf; } } } ) ;j<=M;j++) { resetDeq(); for(int i=N;i;i--) { if(map[i][j]=='.') { popDeq(N-i,len); dp[][i][j]=std::max(dp[][i][j],maxDeq()+N-i); pushDeq(dp[][i][j]+i-N,N-i); } ][i][j]=-inf; } } } memcpy(dp[],dp[],])); } int ans=-inf; ;i<=N;i++) ;j<=M;j++) ans=std::max(ans,dp[][i][j]); printf("%d\n",ans); ; }
Vijos1834 NOI2005 瑰丽华尔兹 动态规划 单调双端队列优化的更多相关文章
- poj 3259 Wormholes : spfa 双端队列优化 判负环 O(k*E)
/** problem: http://poj.org/problem?id=3259 spfa判负环: 当有个点被松弛了n次,则这个点必定为负环中的一个点(n为点的个数) spfa双端队列优化: 维 ...
- 关于SPFA的双端队列优化
7.11 Update 我做题的时候发现这样写会RE 因为在使用双端队列优化SPFA的时候 在将一个点加入队列的时候,如果队列已经空了 那么一旦出现dis[Q.front()]就会RE 可以这样修改 ...
- 2018.09.10 bzoj1499: [NOI2005]瑰丽华尔兹(单调队列优化dp)
传送门 单调队列优化dp好题. 这题其实很简单. 我们很容易想到一个O(T∗n∗m)" role="presentation" style="position: ...
- bzoj1499: [NOI2005]瑰丽华尔兹&&codevs1748 单调队列优化dp
这道题 网上题解还是很多很好的 强烈推荐黄学长 码风真的好看 神犇传送门 学习学习 算是道单调队列优化dp的裸题吧 #include<cstdio> #include<cstring ...
- 洛谷 P2254 [NOI2005]瑰丽华尔兹(单调栈优化DP)
题目描述 不妨认为舞厅是一个N行M列的矩阵,矩阵中的某些方格上堆放了一些家具,其他的则是空地.钢琴可以在空地上滑动,但不能撞上家具或滑出舞厅,否则会损坏钢琴和家具,引来难缠的船长.每个时刻,钢琴都会随 ...
- BZOJ1499:[NOI2005]瑰丽华尔兹(DP,单调队列)
Description 你跳过华尔兹吗?当音乐响起,当你随着旋律滑动舞步,是不是有一种漫步仙境的惬意?众所周知,跳华尔兹时,最重要的是有好的音乐.但是很少有几个人知道,世界上最伟大的钢琴家一生都漂泊在 ...
- BZOJ1499 [NOI2005]瑰丽华尔兹 【单调队列优化dp】
题目 你跳过华尔兹吗?当音乐响起,当你随着旋律滑动舞步,是不是有一种漫步仙境的惬意?众所周知,跳华尔兹时,最重要的是有好的音乐.但是很少有几个人知道,世界上最伟大的钢琴家一生都漂泊在大海上,他的名字叫 ...
- 洛谷P2254 [NOI2005]瑰丽华尔兹(单调队列)
传送门 题解 大概就是设$dp[i][x][y]$表示在第$i$个时间段,在$(x,y)$时的最大滑动距离 然后转移是$dp[i][x][y]=max(dp[i-1][x][y],dp[i][x'][ ...
- LuoguP2254 [NOI2005]瑰丽华尔兹 (单调队列优化DP)(用记忆化过了。。。)
记忆化 #include <cstdio> #include <iostream> #include <cstring> #include <algorith ...
随机推荐
- 【EJS】
// 用=号输出,就会被escapge转义编码 <%= VARIABLE_NAME %> // 用“-”输出原始内容, 不会被escape <%- VARIABLE_NAME %&g ...
- HDU-4089 Activation
http://acm.hdu.edu.cn/showproblem.php?pid=4089 Activation Time Limit: 20000/10000 MS (Java/Others) ...
- rspec学习01
1.安装rspec 2.基本构造 rspec用关键字describe和it,所以我们可以象正常会话一样去表达一个想法. describe方法创建了一个用例组,在describe所在的代码块里,你可以用 ...
- Git error: hint: Updates were rejected because the remote contains work that you do hint: not have locally. This is usually caused b
hint: Updates were rejected because the remote contains work that you dohint: not have locally. This ...
- 《University Calculus》-chape8-无穷序列和无穷级数-基本极限恒等式
基于基本的极限分析方法(诸多的无穷小以及洛必达法则),我们能够得到推导出一些表面上看不是那么显然的式子,这些极限恒等式往往会在其他的推导过程中用到,其中一个例子就是概率论中的极限定理那部分知识.
- openStack云平台虚拟桌面galera mysql 3节点集群实例实战
- [转载]opencv MSER
最大稳定极值区域(MSER-Maximally Stable Extremal Regions)可以用于图像的斑点区域检测.该算法最早是由Matas等人于2002年提出,它是基于分水岭的概念. MSE ...
- flexpaper 背景色变化
1.mxml文件头部:添加 backgroundAlpha="0" <s:Application xmlns:fx="http://ns.adobe.com/mxm ...
- assembly的说明
Assembly SampleAssembly; // Instantiate a target object. Int32 Integer1 = new Int32(); Type Type1; / ...
- NewSQL——优化的SQL存储引擎(TokuDB, MemSQL)+?
NewSQL 是对各种新的可扩展/高性能数据库的简称,这类数据库不仅具有NoSQL对海量数据的存储管理能力,还保持了传统数据库支持ACID和SQL等特性. NewSQL 是指这样一类新式的关系型数据库 ...