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\)的矩形地面,上面有一些障碍(用'#'表示),其余的是空地(用'.'表示).每时每刻,地面都会向某个方向倾斜 ...
随机推荐
- idea下建立bootstrap项目
环境准备: 1.创建一个static web名为bootstrapDemo 2.在bootstrapDemo文件夹下安装bower npm install bower 会自动产生node-module ...
- 关于/usr/bin/ld: cannot find -lcrypto 的错误
Linux下 build code 时,要做 -lssl, -lcrypto 的链接,出现类似下面的错误: /usr/bin/ld: cannot find -lcrypto /usr/bin/ld: ...
- python whl包的安装
1.首先安装PIP. https://pip.pypa.io/en/latest/installing.html#install-pip python get-pip.py 2.设置好环境变量: C: ...
- vector的内存分配机制分析
该程序初步演示了我对vector在分配内存的时候的理解.可能有误差,随着理解的改变,改代码可以被修改. /* 功能说明: vector的内存分配机制分析. 代码说明: vector所管理的内存地址是连 ...
- 【java规则引擎】之Drools引擎中模拟ReteooStatefulSession内部设计结构
该片文章只是抽取drools中java代码实现的一些代码结构,帮助我们理解drools是如何实现rete算法的. 该部分只是抽取ReteooStatefulSession工作过程中的代码架构 利用了多 ...
- JavaScript6 新语法 let 有什么优势
最近看国外的前端代码时,发现ES6的新特性已经相当普及,尤其是 let,应用非常普遍 虽然 let 的用法与 var 相同,但不管是语法语义上,还是性能上,都提升了很多,下面就从这两方面对比一下 语法 ...
- BZOJ2724:[Violet 6]蒲公英
浅谈分块:https://www.cnblogs.com/AKMer/p/10369816.html 题目传送门:https://lydsy.com/JudgeOnline/problem.php?i ...
- BZOJ3624:[APIO2008]免费道路
浅谈并查集:https://www.cnblogs.com/AKMer/p/10360090.html 题目传送门:https://www.lydsy.com/JudgeOnline/problem. ...
- Azure RBAC管理ASM资源
上一篇文章介绍了Azure基于ARM的RBAC,给不同的用户分配不同的权限. 但目前在国内使用的大部分用户还是以ASM的资源为主.比如:VM.Storage.Network.WebAPP.SQL Az ...
- laravel count的使用
rt 学习源头: https://blog.csdn.net/chajinglong/article/details/51954010 四.聚合 查询构建器还提供了各种聚合方法,如统计,马克斯,min ...