题目大意:给定一个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 瑰丽华尔兹 单调队列的更多相关文章

  1. BZOJ 1499 [NOI2005] 瑰丽华尔兹 | 单调队列优化DP

    BZOJ 1499 瑰丽华尔兹 | 单调队列优化DP 题意 有一块\(n \times m\)的矩形地面,上面有一些障碍(用'#'表示),其余的是空地(用'.'表示).每时每刻,地面都会向某个方向倾斜 ...

  2. bzoj 1499 [NOI2005]瑰丽华尔兹——单调队列优化dp

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1499 简单的单调队列优化dp.(然而当时却WA得不行.今天总算填了坑) 注意滚动数组赋初值应 ...

  3. bzoj1499[NOI2005]瑰丽华尔兹 单调队列优化dp

    1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec  Memory Limit: 64 MBSubmit: 1802  Solved: 1097[Submit][Status ...

  4. 【BZOJ1499】[NOI2005]瑰丽华尔兹 单调队列+DP

    [BZOJ1499][NOI2005]瑰丽华尔兹 Description 你跳过华尔兹吗?当音乐响起,当你随着旋律滑动舞步,是不是有一种漫步仙境的惬意?众所周知,跳华尔兹时,最重要的是有好的音乐.但是 ...

  5. ●BZOJ 1499 [NOI2005]瑰丽华尔兹

    题链: http://www.lydsy.com/JudgeOnline/problem.php?id=1499 题解: 单调队列优化DP 定义 dp[t][x][y] 表示第t个时间段之后,处在(x ...

  6. bzoj1499 [NOI2005]瑰丽华尔兹——单调队列优化DP

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1499 朴素DP方程很好想,以右移为例,就是 f[i][x][y]=max(f[i][x][y ...

  7. bzoj 1499: [NOI2005]瑰丽华尔兹【dp+单调队列】

    设f[a][i][j]为第a段时间结束时在(i,j)位置的最长滑行距离,转移很好想,就是分四个方向讨论,然后枚举这段时间的滑行长度取个max即可 但是这样是O(n^4)的,考虑优化 发现同一行或列,取 ...

  8. NOI2005瑰丽华尔兹

    1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec  Memory Limit: 64 MBSubmit: 893  Solved: 508[Submit][Status] ...

  9. [Bzoj1499][NOI2005]瑰丽华尔兹[简单DP]

    1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec  Memory Limit: 64 MBSubmit: 1714  Solved: 1042[Submit][Status ...

随机推荐

  1. iphone开发小记

    程序功能:点击Button实现按钮的文本变换 一,打开Xcode,新建single view based application,拖动一个Button控件到屏幕中间 项目目录树下包含AppDelega ...

  2. [置顶] 基于.NET的快速信息化系统开发框架 — RDIFramework.NET — 系统目录

    基于.NET的快速信息化系统开发整合框架 —RDIFramework.NET—系统目录 框架简单介绍 .NET快速开发整合框架(RDIFramework.NET),基于.NET的快速信息化系统开发.整 ...

  3. CentOS, 高速设置ssh无password登录

    首先.保证能够ping通 然后运行例如以下命令, master登录slave master上面运行例如以下指令: 2.4 确认本机sshd的配置文件(root) $ vi/etc/ssh/sshd_c ...

  4. hdu 4739 Zhuge Liang's Mines (简单dfs)

    Zhuge Liang's Mines Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Othe ...

  5. 利用jxl读取excel合并的单元格的一个小样例

    工作中我们可能要把Excel文件的记录保存到数据库, 今天我用jxl读取Excel文件时遇到了合并格的问题,记录例如以下: 如Excel文件例如以下: watermark/2/text/aHR0cDo ...

  6. EF使用时异常:对一个或多个实体的验证失败。有关详细信息

    //最顶级异常中是不提示具体哪个字段验证失败,必须到详细异常类型中查看 try { //EF操作 } catch (System.Data.Entity.Validation.DbEntityVali ...

  7. js正则表达式验证字符长度

    原理,就是把一个汉字替换为两个字母,来实现长度验证. //js正则验证字符长度 第一种:直接输出长度 alert('1sS#符'.replace(/[^\x00-\xff]/g, 'AA').leng ...

  8. 【转载】Java策略消除if else

    策略(Strategy)模式:又名Policy,它的用意是定义一组算法,把它们一个个封装起来,并且使他们可以相互替换.策略模式可以独立于使用他们的客户端而变化.GOF策略模式静态结构类图如下: 通过上 ...

  9. Unqualified name lookup

    Unqualified name lookup File scope Namespace scope For an qualified name, that is a name that does n ...

  10. [Swust OJ 801]--Ordered Fractions

    题目链接:http://acm.swust.edu.cn/problem/801/ Time limit(ms): 1000 Memory limit(kb): 10000   Description ...