Luogu 2254 [NOI2005]瑰丽华尔兹
简单dp,设$f_{i,j,k}$表示第i个时间段,钢琴处在(j,k)位置移动距离的最大值,那么有转移
$f_{i, j, k} = max(f_{i - 1, j, k}) , f_{i, j, k} = max(f_{i - 1, a, b})$
其中
$j - dx_{d_{i}} * len\leq a \leq j -1 $
$k - dy_{d_{i}} * len\leq b \leq k -1 $
$len = ed_{i} - st_{i} + 1 $
其实就是一个滑动窗口,考虑到转移顺序,就是写四遍单调队列~
但是我成功地把方程写错了…… i - 1 写成了 i ,改掉就A了
Code:
#include <cstdio>
#include <cstring>
#include <cstdlib>
using namespace std; const int N = ; int n, m, segNum, st[N], ed[N], d[N];
int fx, fy, f[N][N][N], q[N];
char mp[N][N]; inline void read(int &X) {
X = ;
char ch = ;
int op = ;
for(; ch > ''|| ch < ''; ch = getchar())
if(ch == '-') op = -;
for(; ch >= '' && ch <= ''; ch = getchar())
X = (X << ) + (X << ) + ch - ;
X *= op;
} inline void chkMax(int &x, int y) {
if(y > x) x = y;
} inline void print(int p) {
printf("\n%d\n", p);
for(int i = ; i <= n; i++, printf("\n"))
for(int j = ; j <= m; j++)
printf("%10d ", f[p][i][j]);
system("pause");
} int main() {
read(n), read(m), read(fx), read(fy), read(segNum);
for(int i = ; i <= n; i++) scanf("%s", mp[i] + );
for(int i = ; i <= segNum; i++)
read(st[i]), read(ed[i]), read(d[i]); memset(f, 0xcf, sizeof(f));
f[][fx][fy] = ;
for(int i = ; i <= segNum; i++) {
for(int j = ; j <= n; j++)
for(int k = ; k <= m; k++)
if(mp[j][k] != 'x') chkMax(f[i][j][k], f[i - ][j][k]); // print(i); int len = ed[i] - st[i] + ;
if(d[i] == ) {
for(int k = ; k <= m; k++) {
int l = , r = ;
for(int j = n; j >= ; j--) {
for(; l <= r && q[l] > j + len; l++);
if(mp[j][k] == 'x') l = , r = ;
else if(l <= r) chkMax(f[i][j][k], f[i - ][q[l]][k] + (q[l] - j));
if(f[i - ][j][k] >= ) {
for(; l <= r && f[i - ][q[r]][k] + (q[r] - j) < f[i - ][j][k]; r--);
q[++r] = j;
}
}
}
} if(d[i] == ) {
for(int k = ; k <= m; k++) {
int l = , r = ;
for(int j = ; j <= n; j++) {
for(; l <= r && q[l] < j - len; l++);
if(mp[j][k] == 'x') l = , r = ;
else if(l <= r) chkMax(f[i][j][k], f[i - ][q[l]][k] + (j - q[l]));
if(f[i - ][j][k] >= ) {
for(; l <= r && f[i - ][q[r]][k] + (j - q[r]) < f[i - ][j][k]; r--);
q[++r] = j;
}
}
}
} if(d[i] == ) {
for(int j = ; j <= n; j++) {
int l = , r = ;
for(int k = m; k >= ; k--) {
for(; l <= r && q[l] > k + len; l++);
if(mp[j][k] == 'x') l = , r = ;
else if(l <= r) chkMax(f[i][j][k], f[i - ][j][q[l]] + (q[l] - k));
if(f[i - ][j][k] >= ) {
for(; l <= r && f[i - ][j][q[r]] + (q[r] - k) < f[i - ][j][k]; r--);
q[++r] = k;
}
}
}
} if(d[i] == ) {
for(int j = ; j <= n; j++) {
int l = , r = ;
for(int k = ; k <= m; k++) {
for(; l <= r && q[l] < k - len; l++);
if(mp[j][k] == 'x') l = , r = ;
else if(l <= r) chkMax(f[i][j][k], f[i - ][j][q[l]] + (k - q[l]));
if(f[i - ][j][k] >= ) {
for(; l <= r && f[i - ][j][q[r]] + (k - q[r]) < f[i - ][j][k]; r--);
q[++r] = k;
}
}
}
} // print(i);
} int ans = ;
for(int i = ; i <= n; i++)
for(int j = ; j <= m; j++)
chkMax(ans, f[segNum][i][j]);
printf("%d\n", ans); return ;
}
还是要仔细a
Luogu 2254 [NOI2005]瑰丽华尔兹的更多相关文章
- luogu P2254 [NOI2005]瑰丽华尔兹
题目链接 luogu P2254 [NOI2005]瑰丽华尔兹 题解 为什么我我我不放放放bzoj的链接呢? 因为打的暴力啊,然后bzojT了呀QAQQQQQ(逃 然后luogu竟然过了呀呀呀 dp[ ...
- 单调队列优化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[NOI2005]瑰丽华尔兹 单调队列优化dp
1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec Memory Limit: 64 MBSubmit: 1802 Solved: 1097[Submit][Status ...
- 【BZOJ1499】[NOI2005]瑰丽华尔兹 单调队列+DP
[BZOJ1499][NOI2005]瑰丽华尔兹 Description 你跳过华尔兹吗?当音乐响起,当你随着旋律滑动舞步,是不是有一种漫步仙境的惬意?众所周知,跳华尔兹时,最重要的是有好的音乐.但是 ...
- [Bzoj1499][NOI2005]瑰丽华尔兹[简单DP]
1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec Memory Limit: 64 MBSubmit: 1714 Solved: 1042[Submit][Status ...
- P2254 [NOI2005]瑰丽华尔兹
链接P2254 [NOI2005]瑰丽华尔兹 首先有个很朴素的\(dp\),设\(f_{i,j,k}\)表示\(k\)时刻地点\(i,j\)的最长长度. 然后这样不能优化,考虑利用一段连续时间是同一个 ...
- 题解-[NOI2005]瑰丽华尔兹
题解-[NOI2005]瑰丽华尔兹 [NOI2005]瑰丽华尔兹 \(n\times m\) 的矩阵.以 \((x,y)\) 为起点.一共 \(k\) 段时间,每段时间为 \([s_i,t_i](t_ ...
- BZOJ 1499 [NOI2005] 瑰丽华尔兹 | 单调队列优化DP
BZOJ 1499 瑰丽华尔兹 | 单调队列优化DP 题意 有一块\(n \times m\)的矩形地面,上面有一些障碍(用'#'表示),其余的是空地(用'.'表示).每时每刻,地面都会向某个方向倾斜 ...
随机推荐
- Python 3.5 socket OSError: [Errno 101] Network is unreachable
/******************************************************************************** * Python 3.5 socke ...
- Buffer 和Cache 的区别
Buffer 和Cache 的区别buffer 与cache 操作的对象就不一样.buffer
- vector的内存分配机制分析
该程序初步演示了我对vector在分配内存的时候的理解.可能有误差,随着理解的改变,改代码可以被修改. /* 功能说明: vector的内存分配机制分析. 代码说明: vector所管理的内存地址是连 ...
- LeetCode Image Smoother
原题链接在这里:https://leetcode.com/problems/image-smoother/description/ 题目: Given a 2D integer matrix M re ...
- jsp中引入JavaScript的方法
1:在页面中直接嵌入JavaScript <script language="javascript">..........</script> 2:链接外部J ...
- MLCC 电容的的 NP0 C0G 材质
MLCC 电容的的 NP0 C0G 材质 随手记一下. MLCC 中最稳定的材质 NP0 C0G,NP0 和 C0G 是相同的,只是不同的产商不同的名字而已. 注意中间的是 0 不是 英文字母 O,虽 ...
- SpringCloud微服务实战——第一章序言读书笔记
什么是微服务架构 是系统架构上的一种设计风格,将独立的系统拆分成多个小型服务,这些小型服务都在各自独立的进程中运行,服务之间基于HTTP的RESTful API进行通信协作. 每个小型服务都围绕各自的 ...
- es6字符串的扩展学习笔记
1. 传统上,JavaScript只有indexOf方法,可以用来确定一个字符串是否包含在另一个字符串中.ES6又提供了三种新方法. includes():返回布尔值,表示是否找到了参数字符串. st ...
- CentOS 7 安装Percona,Xtrabackup
CentOS 7 安装Percona 5.7,Xtrabackup 简介 Percona Server为 MySQL 数据库服务器进行了改进,在功能和性能上较 MySQL 有着很显著的提升.该版本提升 ...
- 在Linux上利用core dump和GDB调试segfault
时常会遇到段错误(segfault),调试非常费劲,除了单元测试和基本测试外,有些时候是在在线环境下,没有基本开发和测试工具,这就需要调试的技能.以前介绍过使用strace进行系统调试和追踪<l ...