bzoj 1499 [NOI2005]瑰丽华尔兹——单调队列优化dp
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1499
简单的单调队列优化dp。(然而当时却WA得不行。今天总算填了坑)
注意滚动数组赋初值应当继承上一次的该位置的值。还有转移的时候取个max。
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int N=,INF=;//
int n,m,x,y,T,l,r,d,dp[][N][N],ans,q[N],h,t;
char ch[N][N];
int main()
{
scanf("%d%d%d%d%d ",&n,&m,&x,&y,&T);
for(int i=;i<=n;i++)cin>>(ch[i]+);
memset(dp,-,sizeof dp);dp[][x][y]=;
for(int s=;s<=T;s++)
{
scanf("%d%d%d",&l,&r,&d);int u=(s&),v=!u;int w=r-l+;
if(d==)
{
// q[0]=n;
for(int j=;j<=m;j++)
{
for(int i=n;i;i--)
{
dp[u][i][j]=dp[v][i][j];//
if(ch[i][j]=='x')
{
// h=0;t=0;q[0]=i-1;continue;
h=;t=;continue;
}
while(h<=t&&q[h]-i>w)h++;
while(h<=t&&dp[v][i][j]>=dp[v][q[t]][j]+(q[t]-i))t--;q[++t]=i;
if(dp[v][q[h]][j]>-INF||(q[h]==x&&j==y))dp[u][i][j]=max(dp[u][i][j],dp[v][q[h]][j]+(q[h]-i));//
// printf("dp[%d][%d]=%d(dp[%d][%d]=%d i=%d q[%d]=%d)\n",i,j,dp[u][i][j],q[h],j,dp[v][q[h]][j],i,h,q[h]);
}
h=;t=;//
}
}
else if(d==)
{
// q[0]=1;
for(int j=;j<=m;j++)
{
for(int i=;i<=n;i++)
{
dp[u][i][j]=dp[v][i][j];//
if(ch[i][j]=='x')
{
// h=0;t=0;q[0]=i+1;continue;
h=;t=;continue;
}
while(h<=t&&i-q[h]>w)h++;
while(h<=t&&dp[v][i][j]>=dp[v][q[t]][j]+(i-q[t]))t--;q[++t]=i;
if(dp[v][q[h]][j]>-INF||(q[h]==x&&j==y))dp[u][i][j]=max(dp[u][i][j],dp[v][q[h]][j]+(i-q[h]));//
// printf("dp[%d][%d]=%d(dp[%d][%d]=%d i=%d q[%d]=%d)\n",i,j,dp[u][i][j],q[h],j,dp[v][q[h]][j],i,h,q[h]);
}
h=;t=;//
}
}
else if(d==)
{
// q[0]=m;
for(int i=;i<=n;i++)
{
for(int j=m;j;j--)
{
dp[u][i][j]=dp[v][i][j];//
if(ch[i][j]=='x')
{
// h=0;t=0;q[0]=j-1;continue;
h=;t=;continue;
}
while(h<=t&&q[h]-j>w)h++;
while(h<=t&&dp[v][i][j]>=dp[v][i][q[t]]+(q[t]-j))t--;q[++t]=j;
if(dp[v][i][q[h]]>-INF||(i==x&&q[h]==y))dp[u][i][j]=max(dp[u][i][j],dp[v][i][q[h]]+(q[h]-j));//
// printf("dp[%d][%d]=%d(dp[%d][%d]=%d j=%d q[%d]=%d)\n",i,j,dp[u][i][j],i,q[h],dp[v][i][q[h]],j,h,q[h]);
}
h=;t=;//
}
}
else{
// q[0]=1;
for(int i=;i<=n;i++)
{
for(int j=;j<=m;j++)
{
dp[u][i][j]=dp[v][i][j];//
if(ch[i][j]=='x')
{
// h=0;t=0;q[0]=j+1;continue;
h=;t=;continue;
}
while(h<=t&&j-q[h]>w)h++;
while(h<=t&&dp[v][i][j]>=dp[v][i][q[t]]+(j-q[t]))t--;q[++t]=j;
if(dp[v][i][q[h]]>-INF||(i==x&&q[h]==y))dp[u][i][j]=max(dp[u][i][j],dp[v][i][q[h]]+(j-q[h]));//
// printf("dp[%d][%d]=%d(dp[%d][%d]=%d j=%d q[%d]=%d)\n",i,j,dp[u][i][j],q[h],j,dp[v][q[h]][j],j,h,q[h]);
}
h=;t=;//
}
}
}
int u=(T&);
for(int i=;i<=n;i++) for(int j=;j<=m;j++) ans=max(ans,dp[u][i][j]);
printf("%d",ans);
return ;
}
bzoj 1499 [NOI2005]瑰丽华尔兹——单调队列优化dp的更多相关文章
- BZOJ 1499 [NOI2005] 瑰丽华尔兹 | 单调队列优化DP
BZOJ 1499 瑰丽华尔兹 | 单调队列优化DP 题意 有一块\(n \times m\)的矩形地面,上面有一些障碍(用'#'表示),其余的是空地(用'.'表示).每时每刻,地面都会向某个方向倾斜 ...
- bzoj1499[NOI2005]瑰丽华尔兹 单调队列优化dp
1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec Memory Limit: 64 MBSubmit: 1802 Solved: 1097[Submit][Status ...
- BZOJ 1499 NOI2005 瑰丽华尔兹 单调队列
题目大意:给定一个m*n的地图,一些点有障碍物,钢琴初始在一个点,每一个时间段能够选择向给定的方向移动一段距离,求最长路径长 朴素DP的话,我们有T个时间段,每一个时间段有m*n个点,n个时间,一定会 ...
- bzoj1499 [NOI2005]瑰丽华尔兹——单调队列优化DP
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1499 朴素DP方程很好想,以右移为例,就是 f[i][x][y]=max(f[i][x][y ...
- ●BZOJ 1499 [NOI2005]瑰丽华尔兹
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=1499 题解: 单调队列优化DP 定义 dp[t][x][y] 表示第t个时间段之后,处在(x ...
- 【BZOJ1499】[NOI2005]瑰丽华尔兹 单调队列+DP
[BZOJ1499][NOI2005]瑰丽华尔兹 Description 你跳过华尔兹吗?当音乐响起,当你随着旋律滑动舞步,是不是有一种漫步仙境的惬意?众所周知,跳华尔兹时,最重要的是有好的音乐.但是 ...
- BZOJ 3126 [USACO2013 Open]Photo (单调队列优化DP)
洛谷传送门 题目大意:给你一个长度为$n$的序列和$m$个区间,每个区间内有且仅有一个1,其它数必须是0,求整个序列中数字1最多的数量 神题,竟然是$DP$ 定义$f_{i}$表示第i位放一个1时,最 ...
- bzoj 3831 Little Bird (单调队列优化dp)
/*先贴个n*n的*/ #include<iostream> #include<cstdio> #include<cstring> #define maxn 100 ...
- bzoj 3126: [Usaco2013 Open]Photo——单调队列优化dp
Description 给你一个n长度的数轴和m个区间,每个区间里有且仅有一个点,问能有多少个点 Input * Line 1: Two integers N and M. * Lines 2..M+ ...
随机推荐
- Linux中显示空闲内存空间的free命令的基本用法
free 命令显示系统使用和空闲的内存情况,包括物理内存.交互区内存(swap)和内核缓冲区内存 参数 -b 显示内存的单位为字节-k 显示内存的单位为 KB-m 显示内存的单位为 M-o 忽略缓冲区 ...
- 混合开发的大趋势之 一个Android程序员眼中的 React.js 箭头函数,const, PropTypes
转载请注明出处:王亟亟的大牛之路 昨天写了篇React.js的开头之作,讲了讲块级作用域和let,先安利:https://github.com/ddwhan0123/Useful-Open-Sourc ...
- 【bzoj4806~bzoj4808】炮车马后——象棋四连击
bzoj4806——炮 题目传送门:bzoj4806 这种题一看就是dp...我们可以设$ f[i][j][k] $表示处理到第$ i $行,有$ j $列没放炮,$ k $列只放了一个炮.接着分情况 ...
- 自然语言处理中的语言模型预训练方法(ELMo、GPT和BERT)
自然语言处理中的语言模型预训练方法(ELMo.GPT和BERT) 最近,在自然语言处理(NLP)领域中,使用语言模型预训练方法在多项NLP任务上都获得了不错的提升,广泛受到了各界的关注.就此,我将最近 ...
- SpringBoot配置文件 application.properties详解
SpringBoot配置文件 application.properties详解 本文转载:https://www.cnblogs.com/louby/p/8565027.html 阅读过程中若发现 ...
- Text Justification,文本对齐
问题描述:把一个集合的单词按照每行L个字符放,每行要两端对齐,如果空格不能均匀分布在所有间隔中,那么左边的空格要多于右边的空格,最后一行靠左对齐. words: ["This", ...
- scala学习手记37 - 容器的使用
这次统一看一下scala中容器类的几个方法. Set filter()方法 filter()方法用来从Set中过滤获取含有指定特征的元素.示例代码如下: val colors1 = Set(" ...
- angular指令详解--自定义指令
自定义指令 directive()这个方法是用来定义指令的: angular.module('myApp', []) .directive('myDirective', function ($time ...
- win8 商店应用 设计风格原则
共八条: 1,突出内容(数据). a,仅在屏幕上保留最相关的元素:移除线条.框和不必要的图形效果:限制屏幕上持久显示的导航框,如选项卡. b,交互尽量直接在内容上,直接控制内容来完成操作,而不是使用控 ...
- canvas - 饼状图
<!DOCTYPE html> <html> <head> <title>Canvas测试</title> <meta charset ...