【bzoj1499】瑰丽华尔兹
这名字听起来实在有点耳熟。。?
好吧去年暑假就应该过的题。。。切了
先注意到,天使施魔法的次数不限;我们可以使得某个时刻在特定方向移动一段距离(最长的长度为那个时间段)然后怎么来考虑这个DP;
T,X,Y三维状态很好想到,刚开始的时刻是1,T-1的方向已知,要么从那个方向移动到X,Y,要么在此位置不动。现在来优化这个DP。我们的动机是把O(N*M*T)->O(N*M*K),至于为什么要这要做。。。(题感啊题感,所有的优化都是优化转移嘛不可能优化状态了,所以当转移都无法优化的时候我们只能考虑来改变这个状态。K是时间段的个数,可以想到,其实在同一时间段里面,操作几乎都是相同的。那么dp[K][X][Y]表示在K这段时间内,位于(X,Y)这个位置,从时段1到时段K的最大位移。那么转移就成为了:dp[K][X][Y]=MAX{dp[K-1][X'][Y']+DIST}
*举个例子,假如当前时间段朝向是往右,那么dp[k][x][y]=max{dp[k-1][x][y-Δy]+Δy}=y+max{dp[k-1][x][y']-y'},Δy自然要小于等于当前时间段的长度。现在转移就可以被优化了,我们把k-1时间段的状态记载下来,保证单调递减就OK了,其它三个方向也是类似的:
left:dp[k][x][y]=max{dp[k-1][x][y']+y'}-y
up:dp[k][x][y]=max(dp[k-1][x'][y]+x'}-x
down:dp[k][x][y]=max(dp[k-1][x'][y]-x'}+x
在执行队列的过程中我们有几个需要维护的地方,如果当前自己是家具,那么没关系,我们清空队列;
如果要放进的那个是不合法的,那就不放。
CODE:
#include<cstdio>
#include<cstring>
#include<algorithm>
#define N 300
using namespace std;
int n,m,x0,y0,k,ans;
][][];
];
int main()
{
];
scanf("%d%d%d%d%d",&n,&m,&x0,&y0,&k);
;i<=n;i++)
{
scanf("%s",s);
;j<=m;j++)
]==;
}
;i<=k;i++)scanf("%d%d%d",&st[i],&ed[i],&ff[i]);
memset(dp,-,sizeof(dp));
dp[][x0][y0]=;
;i<=k;i++)
{
);
){//向右
;xx<=n;xx++)
{
,tail=;q[].x=dp[i-][xx][]-;q[].h=;
][xx][]==-)tail--;
;yy<=m;yy++)
{
while(tou<=tail&&(yy-q[tou].h>len))tou++;
)if(tou<=tail)dp[i][xx][yy]=q[tou].x+yy;
//if(dp[i][xx][yy]>-1)printf("you===%d %d %d %d %d\n",i,xx,yy,dp[i][xx][yy],q[tou].h);
){tail=tou-;}
][xx][yy+]==-)continue;
][xx][yy+]-yy->q[tail].x)tail--;
tail++;q[tail].x=dp[i-][xx][yy+]-yy-;q[tail].h=yy+;
}
}
}
)//left
{
;xx<=n;xx++)
{
,tail=;q[].x=dp[i-][xx][m]+m;q[].h=m;
][xx][m]==-)tail--;
;yy--)
{
while(tou<=tail&&q[tou].h-yy>len)tou++;
)if(tou<=tail)dp[i][xx][yy]=q[tou].x-yy;
//if(dp[i][xx][yy]>-1)printf("zuo===%d %d %d %d %d\n",i,xx,yy,dp[i][xx][yy],q[tou].h);
)tail=tou-;
][xx][yy-]==-)continue;
][xx][yy-]+yy->q[tail].x)tail--;
tail++;q[tail].x=dp[i-][xx][yy-]+yy-;q[tail].h=yy-;
}
}
}
)//向上
{
;yy<=m;yy++)
{
,tail=;q[].x=dp[i-][n][yy]+n;q[].h=n;
][n][yy]==-)tail--;
;xx--)
{
while(tou<=tail&&q[tou].h-xx>len)tou++;
)if(tou<=tail)dp[i][xx][yy]=q[tou].x-xx;
//if(dp[i][xx][yy]>-1)printf("up===%d %d %d %d %d\n",i,xx,yy,dp[i][xx][yy],q[tou].h);
)tail=tou-;
][xx-][yy]==-)continue;
][xx-][yy]+xx->q[tail].x)tail--;
tail++;q[tail].x=dp[i-][xx-][yy]+xx-;q[tail].h=xx-;
}
}
}
)//xia
{
;yy<=m;yy++)//down
{
,tail=;q[].x=dp[i-][][yy]-;q[].h=;
][][yy]==-)tail--;
;xx<=n;xx++)
{
while(tou<=tail&&xx-q[tou].h>len)tou++;
)if(tou<=tail)dp[i][xx][yy]=q[tou].x+xx;
//if(dp[i][xx][yy]>-1)printf("xia===%d %d %d %d %d\n",i,xx,yy,dp[i][xx][yy],q[tou].h);
)tail=tou-;
][xx+][yy]==-)continue;
][xx+][yy]-xx->q[tail].x)tail--;
tail++;q[tail].x=dp[i-][xx+][yy]-xx-;q[tail].h=xx+;
}
}
}
}
;i<=n;i++)
;j<=m;j++)
if(dp[k][i][j]>ans)ans=dp[k][i][j];
//printf("%d %d %d\n",i,j,dp[k][i][j]);
printf("%d",ans);
}
【bzoj1499】瑰丽华尔兹的更多相关文章
- 洛谷2254 BZOJ1499 瑰丽华尔兹题解
洛谷链接 BZ链接 一个很容易想到的做法就是用f[i][j][t]表示t时刻在i,j处的可以滑动的最大值 f[i][j][t]=max(f[i][j][t-1],f[*i][*j][t-1]),这样大 ...
- 【BZOJ1499】瑰丽华尔兹(动态规划)
[BZOJ1499]瑰丽华尔兹(动态规划) 题面 BZOJ 题解 先写部分分 设\(f[t][i][j]\)表示当前在\(t\)时刻,位置在\(i,j\)时走的最多的步数 这样子每一步要么停要么走 时 ...
- 【BZOJ1499】【NOI2005】瑰丽华尔兹(动态规划)
[BZOJ1499]瑰丽华尔兹(动态规划) 题面 BZOJ 题解 先写部分分 设\(f[t][i][j]\)表示当前在\(t\)时刻,位置在\(i,j\)时走的最多的步数 这样子每一步要么停要么走 时 ...
- 【BZOJ1499】[NOI2005]瑰丽华尔兹 单调队列+DP
[BZOJ1499][NOI2005]瑰丽华尔兹 Description 你跳过华尔兹吗?当音乐响起,当你随着旋律滑动舞步,是不是有一种漫步仙境的惬意?众所周知,跳华尔兹时,最重要的是有好的音乐.但是 ...
- bzoj1499[NOI2005]瑰丽华尔兹 单调队列优化dp
1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec Memory Limit: 64 MBSubmit: 1802 Solved: 1097[Submit][Status ...
- [Bzoj1499][NOI2005]瑰丽华尔兹[简单DP]
1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec Memory Limit: 64 MBSubmit: 1714 Solved: 1042[Submit][Status ...
- DP+单调队列 codevs 1748 瑰丽华尔兹(还不是很懂具体的代码实现)
codevs 1748 瑰丽华尔兹 2005年NOI全国竞赛 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 大师 Master 题解 题目描述 Descripti ...
- NOI2005瑰丽华尔兹
1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec Memory Limit: 64 MBSubmit: 893 Solved: 508[Submit][Status] ...
- BZOJ 1499 [NOI2005] 瑰丽华尔兹 | 单调队列优化DP
BZOJ 1499 瑰丽华尔兹 | 单调队列优化DP 题意 有一块\(n \times m\)的矩形地面,上面有一些障碍(用'#'表示),其余的是空地(用'.'表示).每时每刻,地面都会向某个方向倾斜 ...
- luogu P2254 [NOI2005]瑰丽华尔兹
题目链接 luogu P2254 [NOI2005]瑰丽华尔兹 题解 为什么我我我不放放放bzoj的链接呢? 因为打的暴力啊,然后bzojT了呀QAQQQQQ(逃 然后luogu竟然过了呀呀呀 dp[ ...
随机推荐
- bzoj 1065: [NOI2008] 奥运物流
1065: [NOI2008] 奥运物流 Description 2008北京奥运会即将开幕,举国上下都在为这一盛事做好准备.为了高效率.成功地举办奥运会,对物流系统 进行规划是必不可少的.物流系统由 ...
- struts文件上传,获取文件名和文件类型
struts文件上传,获取文件名和文件类型 Action中还有两个属 性:uploadFileName和uploadContentType,这两个属性分别用于封装上传文件的文件名.文件类型.这是S ...
- 大熊君JavaScript插件化开发------(实战篇之DXJ UI ------ ItemSelector重构完结版)
一,开篇分析 Hi,大家好!大熊君又和大家见面了,还记得上一篇文章吗.主要讲述了以“jQuery的方式如何开发插件”,以及过程化设计与面向对象思想设计相结合的方式是 如何设计一个插件的,两种方式各有利 ...
- Hadoop 2.6.0+ZooKeeper+Hive HA高可用集群安装
http://blog.csdn.net/totxian/article/details/45248399
- JSP脚本中的9个内置对象
JSP脚本中包含9个内置对象,这9个内置对象都是Servlet API接口的实例,只是JSP规范对它们进行了默认初始化.也就是说它们已经是对象,可以直接使用. 我们随意打开一个由JSP页面生成的Ser ...
- Mac Pro 资源管理器 Double Commander“个性化设置” 备份
操作系统自带的资源管理器,总是有些别扭的地方,在 Windows 系统下,我一般用 Total Commander(破解版)来作为替代品.现在换为 Mac 系统,自带的 Finer 也不怎么好用,连最 ...
- JAVA解析XML的四种方法
XML文件:test.xml <?xml version="1.0" encoding="UTF-8"?> <employees> &l ...
- Uva 2319
理解:区域覆盖.假设该点在勘测半圆的边缘,求出与该点可在一个半圆的坐标范围l,r,然后,for 一次判断 #include<cstdio> #include<algorithm> ...
- jquery.print.js 打印插件
<script language="javascript" src="jquery-1.4.4.min.js"></script> &l ...
- (备忘)Rect和RectF的区别
1.Rect的变量使用int类型,而RectF使用float类型. 2.一些方法区别 <1>.Rect类 equals(Object obj) (for some reason it as ...