BZOJ 1499 NOI2005 瑰丽华尔兹 单调队列
题目大意:给定一个m*n的地图,一些点有障碍物,钢琴初始在一个点,每一个时间段能够选择向给定的方向移动一段距离,求最长路径长
朴素DP的话,我们有T个时间段,每一个时间段有m*n个点,n个时间,一定会超时
考虑到一个时间段全部的更新操作都是同样的,我们能够考虑单调队列优化
设队尾为(x,y),新插入的点为(x',y'),那么当Distance( (x,y) , (x',y') ) <= f[x'][y'] - f[x][y]时,(x,y)可被删掉
四遍单调队列就可以 O(T*m*n)
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define M 210
using namespace std;
typedef pair<int,int> abcd;
int n,m,k,ans;
char map[M][M];
int f[M][M],g[M][M];
abcd q[M];int r,h;
inline int Distance(const abcd &x,const abcd &y)
{
return abs(x.first-y.first)+abs(x.second-y.second);
}
inline void Insert(const abcd &x)
{
while( r!=h && Distance(x,q[r]) <= f[x.first][x.second] - f[q[r].first][q[r].second] )
--r;
q[++r]=x;
}
inline int Get_Ans(const abcd &x,int len)
{
while( r!=h && Distance(q[h+1],x)>len )
++h;
if(r==h)
return 0xefefefef;
return f[q[h+1].first][q[h+1].second]+Distance(q[h+1],x);
}
void U(int len)
{
int i,j;
for(j=1;j<=n;j++)
{
r=h=0;
for(i=m;i;i--)
if(map[i][j]=='.')
{
abcd p(i,j);
g[i][j]=max( f[i][j] , Get_Ans(p,len) );
Insert(p);
}
else
r=h=0;
}
memcpy(f,g,sizeof f);
}
void D(int len)
{
int i,j;
for(j=1;j<=n;j++)
{
r=h=0;
for(i=1;i<=m;i++)
if(map[i][j]=='.')
{
abcd p(i,j);
g[i][j]=max( f[i][j] , Get_Ans(p,len) );
Insert(p);
}
else
r=h=0;
}
memcpy(f,g,sizeof f);
}
void L(int len)
{
int i,j;
for(i=1;i<=m;i++)
{
r=h=0;
for(j=n;j;j--)
if(map[i][j]=='.')
{
abcd p(i,j);
g[i][j]=max( f[i][j] , Get_Ans(p,len) );
Insert(p);
}
else
r=h=0;
}
memcpy(f,g,sizeof f);
}
void R(int len)
{
int i,j;
for(i=1;i<=m;i++)
{
r=h=0;
for(j=1;j<=n;j++)
if(map[i][j]=='.')
{
abcd p(i,j);
g[i][j]=max( f[i][j] , Get_Ans(p,len) );
Insert(p);
}
else
r=h=0;
}
memcpy(f,g,sizeof f);
}
int main()
{
int i,j,x,y,z;
cin>>m>>n>>x>>y>>k;
for(i=1;i<=m;i++)
scanf("%s",map[i]+1);
memset(f,0xef,sizeof f);
memset(g,0xef,sizeof g);
f[x][y]=0;
for(i=1;i<=k;i++)
{
scanf("%d%d%d",&x,&y,&z);
switch(z)
{
case 1:U(y-x+1);break;
case 2:D(y-x+1);break;
case 3:L(y-x+1);break;
case 4:R(y-x+1);break;
}
}
for(i=1;i<=m;i++)
for(j=1;j<=n;j++)
ans=max(ans,f[i][j]);
cout<<ans<<endl;
}
BZOJ 1499 NOI2005 瑰丽华尔兹 单调队列的更多相关文章
- BZOJ 1499 [NOI2005] 瑰丽华尔兹 | 单调队列优化DP
BZOJ 1499 瑰丽华尔兹 | 单调队列优化DP 题意 有一块\(n \times m\)的矩形地面,上面有一些障碍(用'#'表示),其余的是空地(用'.'表示).每时每刻,地面都会向某个方向倾斜 ...
- bzoj 1499 [NOI2005]瑰丽华尔兹——单调队列优化dp
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1499 简单的单调队列优化dp.(然而当时却WA得不行.今天总算填了坑) 注意滚动数组赋初值应 ...
- bzoj1499[NOI2005]瑰丽华尔兹 单调队列优化dp
1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec Memory Limit: 64 MBSubmit: 1802 Solved: 1097[Submit][Status ...
- 【BZOJ1499】[NOI2005]瑰丽华尔兹 单调队列+DP
[BZOJ1499][NOI2005]瑰丽华尔兹 Description 你跳过华尔兹吗?当音乐响起,当你随着旋律滑动舞步,是不是有一种漫步仙境的惬意?众所周知,跳华尔兹时,最重要的是有好的音乐.但是 ...
- ●BZOJ 1499 [NOI2005]瑰丽华尔兹
题链: http://www.lydsy.com/JudgeOnline/problem.php?id=1499 题解: 单调队列优化DP 定义 dp[t][x][y] 表示第t个时间段之后,处在(x ...
- 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]瑰丽华尔兹【dp+单调队列】
设f[a][i][j]为第a段时间结束时在(i,j)位置的最长滑行距离,转移很好想,就是分四个方向讨论,然后枚举这段时间的滑行长度取个max即可 但是这样是O(n^4)的,考虑优化 发现同一行或列,取 ...
- NOI2005瑰丽华尔兹
1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec Memory Limit: 64 MBSubmit: 893 Solved: 508[Submit][Status] ...
- [Bzoj1499][NOI2005]瑰丽华尔兹[简单DP]
1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec Memory Limit: 64 MBSubmit: 1714 Solved: 1042[Submit][Status ...
随机推荐
- HDU 3015 Disharmony Trees
题解:在路边有一行树,给出它们的坐标和高度,先按X坐标排序.记录排名,记为rankx,再按它们的高度排序,记录排名,记为rankh.两颗树i,j的差异度为 fabs(rankx[i]-rankx[j] ...
- hdoj 3478 Catch(二分图判定+并查集)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3478 思路分析:该问题需要求是否存在某一个时刻,thief可能存在图中没一个点:将该问题转换为图论问题 ...
- C标准函数库中获取时间与日期、对时间与日期数据操作及格式化
表示时间的三种数据类型[编辑] 日历时间(calendar time),是从一个标准时间点(epoch)到现在的时间经过的秒数,不包括插入闰秒对时间的调整.开始计时的标准时间点,各种编译器一般使用19 ...
- 浅谈web前端开发阅历
WEB前端研发工程师,在国内算是一个朝阳职业,这个领域没有学校的正轨教育,大多数人都是靠本人自学成才.本文次要引见本人从事web开发以来(从大二至今)看过的书籍和本人的成长过程,目的是给想了解Java ...
- Definitions
Definitions and ODR Definitions are declarations that fully define the entity introduced by the decl ...
- C++对象的销毁
- virtual host
<VirtualHost *:80> ServerAdmin webmaster@dummy-host.php100.com DocumentRoot "G:/w ...
- (C)高级排序法
1.快速排序法 //方法1 从大到小 #include <iostream.h> void run(int* pData,int left,int right) { int i,j; in ...
- clear伪类使用
都知道float会脱离文档流 用什么办法撑开父元素呢? 手动在本区块的所有float元素之后加上一个块元素并对其添加clear:both 可以 但是这样还要再去修改html页面 而且多了一个仅仅是 ...
- Tomcat中配置自定义404错误页面
404,50x这种错误经常遇到. 如果%CATALINA_HOME%\conf\web.xml和具体应用中都有设置%CATALINA_HOME%\webapps\ROOT\WEB-INF\web.xm ...