[BZOJ 1499] 瑰丽华尔兹
Link:https://www.lydsy.com/JudgeOnline/problem.php?id=1499
Solution :
能立即发现这是和动态规划相关的题目
令f[t][i][j]表示第t段时间时,钢琴位于(i,j)处时,从第1段时间到第t段时间的最长滑行路程。
f[t][i][j]=max{ f[t−1][i last][j last] + dist{ (i last,j last) , (i,j) } }
由于四个方向的处理类似,这里以向右举例:
f[t][i][j]=max{ f[t−1][i][j′] + (j−j′) }=j+max{f[t−1][i][j′]−j′} , j−j′≤end-start+1
对于每个f[t][i][j],我们就是找到最大的max{f[t−1][i][j′]−j′},同时使得j−j′≤end-start+1
由于j-j'单调递减,每次需要弹出队首元素,我们使用单调队列而非单调栈来维护这个序列
#include <bits/stdc++.h> using namespace std;
const int MAXN=;
const int INF=<<; inline int read()
{
char ch;int num,f=;
while(!isdigit(ch=getchar())) f|=(ch=='-');
num=ch-'';
while(isdigit(ch=getchar())) num=num*+ch-'';
return f?-num:num;
} int n,m,X,Y,k,dp[][MAXN][MAXN],d=; //滚动数组优化
char dat[MAXN][MAXN]; int st,end,dir,res=,que[MAXN],t[MAXN];
int dx[]={,-,,,},dy[]={,,,-,}; void solve(int x,int y)
{
int l=,r=,now=;
while(x>= && x<=n && y>= && y<=m)
{
if(dat[x][y]=='x') l=,r=;
while(l<=r && now-t[l]>end-st+) l++; //弹出队首
while(l<=r && que[r]<dp[d^][x][y]-now) r--; //保证递减的单调性
que[++r]=dp[d^][x][y]-now;t[r]=now;
dp[d][x][y]=que[l]+now; res=max(res,dp[d][x][y]);now++;
x+=dx[dir];y+=dy[dir];
}
} int main()
{
cin >> n >> m >> X >> Y >> k;
for(int i=;i<=n;i++)
for(int j=;j<=m;j++)
cin >> dat[i][j];
memset(dp,0x80,sizeof(dp)); dp[][X][Y]=;
for(int i=;i<=k;i++)
{
st=read(),end=read(),dir=read();
d^=;
if(dir==)
for(int i=;i<=m;i++) solve(n,i);
else if(dir==)
for(int i=;i<=m;i++) solve(,i);
else if(dir==)
for(int i=;i<=n;i++) solve(i,m);
else
for(int i=;i<=n;i++) solve(i,);
}
cout << res;
return ;
}
[BZOJ 1499] 瑰丽华尔兹的更多相关文章
- BZOJ 1499 [NOI2005] 瑰丽华尔兹 | 单调队列优化DP
		
BZOJ 1499 瑰丽华尔兹 | 单调队列优化DP 题意 有一块\(n \times m\)的矩形地面,上面有一些障碍(用'#'表示),其余的是空地(用'.'表示).每时每刻,地面都会向某个方向倾斜 ...
 - 单调队列优化DP || [NOI2005]瑰丽华尔兹 || BZOJ 1499 || Luogu P2254
		
题外话:题目极好,做题体验极差 题面:[NOI2005]瑰丽华尔兹 题解: F[t][i][j]表示第t时刻钢琴位于(i,j)时的最大路程F[t][i][j]=max(F[t-1][i][j],F[t ...
 - NOI2005瑰丽华尔兹
		
1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec Memory Limit: 64 MBSubmit: 893 Solved: 508[Submit][Status] ...
 - 【BZOJ1499】瑰丽华尔兹(动态规划)
		
[BZOJ1499]瑰丽华尔兹(动态规划) 题面 BZOJ 题解 先写部分分 设\(f[t][i][j]\)表示当前在\(t\)时刻,位置在\(i,j\)时走的最多的步数 这样子每一步要么停要么走 时 ...
 - bzoj1499[NOI2005]瑰丽华尔兹 单调队列优化dp
		
1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec Memory Limit: 64 MBSubmit: 1802 Solved: 1097[Submit][Status ...
 - 【BZOJ1499】【NOI2005】瑰丽华尔兹(动态规划)
		
[BZOJ1499]瑰丽华尔兹(动态规划) 题面 BZOJ 题解 先写部分分 设\(f[t][i][j]\)表示当前在\(t\)时刻,位置在\(i,j\)时走的最多的步数 这样子每一步要么停要么走 时 ...
 - luogu P2254 [NOI2005]瑰丽华尔兹
		
题目链接 luogu P2254 [NOI2005]瑰丽华尔兹 题解 为什么我我我不放放放bzoj的链接呢? 因为打的暴力啊,然后bzojT了呀QAQQQQQ(逃 然后luogu竟然过了呀呀呀 dp[ ...
 - [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 ...
 
随机推荐
- NEYC 2017 游记
			
day 1: result: sum_rank: 11 school_rank:1 水题在你高估的时候就已经不水了 sum:有个快速乘类似快速幂: int ans=0; ...
 - HDU4370:0 or 1(最短路)
			
0 or 1 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4370 Description: Given a n*n matrix Cij (1< ...
 - Every Programmer Should Know These Latency Numbers
			
Every Programmer Should Know These Latency Numbers 1秒=1000毫秒(ms) 1秒=1,000,000 微秒(μs) 1秒=1,000,000,00 ...
 - Spring Boot(一)
			
1.注解 @EnableAutoConfiguration 官方文档:The @EnableAutoConfiguration annotation is often placed on your ...
 - im4java学习---阅读documentation文档
			
Utilities----im提供的一些工具类 ①.读取图片文件信息---Info类 我们之前的做法: op.format("width:%w,height:%h,path:%d%f,siz ...
 - centos7下yum快速安装 mariadb(mysql)
			
从最新版本的centos系统开始,默认的是 Mariadb而不是mysql! 使用系统自带的repos安装很简单: yum install mariadb mariadb-server systemc ...
 - React事件处理程序
			
function ActionLink() { function handleClick(e) { e.preventDefault(); console.log('The link was clic ...
 - Linux 通过ssh传输文件
			
一.scp是什么? scp是secure copy的简写,用于在Linux下进行远程拷贝文件的命令,和它类似的命令有cp,不过cp只是在本机进行拷贝不能跨服务器,而且scp传输是加密的.可能会稍微影响 ...
 - 爆破phpmyadmin小脚本
			
#!usr/bin/env python #encoding: utf-8 #by i3ekr import requests headers = {'Content-Type':'applicati ...
 - 【Uva11762】Race to 1
			
模拟马尔可夫过程,具体看书. #include<bits/stdc++.h> #define N 1000010 using namespace std; ; void calcprime ...