题目大意:给定一个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. WPF 自定义TextBox

    1.TextBox前加图标. 效果: <TextBox Width="300" Height="30" Style="{StaticResour ...

  2. Android中获取系统的时间

    activity代码 public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); set ...

  3. 使用C#对MongoDB中的数据进行查询,改动等操作

    首先,使用的是官方提供的C#訪问组件https://github.com/mongodb/mongo-csharp-driver 然后.编译后引用MongoDB.Bson.dll及MongoDB.Dr ...

  4. ping的意思

    Ping是测试网络联接状况以及信息包发送和接收状况非常有用的工具,是网络测试最常用的命令.Ping向目标主机(地址)发送一个回送请求数据包,要求目标主机收到请求后给予答复,从而判断网络的响应时间和本机 ...

  5. 微信网页签名失败(invalid signature)

    签名失败,建议按以下步骤排查 确认签名算法正确,可用 http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisign 页面工具进行校验. 确认con ...

  6. JavaScript中cookie的路径(path)和域(domain)

    cookie虽然是由一个网页所创建,但并不只是创建cookie的网页才能读 取该cookie.在默认情况下,与创建cookie的网页在同一目录或子目录下的所有网页都可以读取该cookie.但如果在这个 ...

  7. 【转】Ubuntu下deb包的安装方法

    [转]Ubuntu下deb包的安装方法 deb是debian linus的安装格式,跟red hat的rpm非常相似,最基本的安装命令是:dpkg -i file.deb dpkg 是Debian P ...

  8. html相关介绍

    HTML(超文本标记语言)  超文本标记语言,即HTML(Hypertext Markup Language),是用于描述网页文档的一种标记语言 XHTML1.0 可扩展超文本置标语言(eXtensi ...

  9. 使用autoCompleteTextView以及MultiAutoCompleteTextView实现自动匹配输入内容

    一:autoCompleteTextView 1:控件属性设置: 注意添加:android:completionThreshold="1"来设置输入几个字符的时候开始显示匹配的内容 ...

  10. String to Integer (atoi) - 复杂的测试

    这个题..是要把字符串转为整数.注意是整数,我看到整数的时候松了一口气,没有小数点的判断应该更好做.而且基本的转化函数我想每个程序员都无法忘记: res=res*+(str[i]-'); 其实就是这么 ...