简单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]瑰丽华尔兹的更多相关文章

  1. luogu P2254 [NOI2005]瑰丽华尔兹

    题目链接 luogu P2254 [NOI2005]瑰丽华尔兹 题解 为什么我我我不放放放bzoj的链接呢? 因为打的暴力啊,然后bzojT了呀QAQQQQQ(逃 然后luogu竟然过了呀呀呀 dp[ ...

  2. 单调队列优化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 ...

  3. NOI2005瑰丽华尔兹

    1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec  Memory Limit: 64 MBSubmit: 893  Solved: 508[Submit][Status] ...

  4. bzoj1499[NOI2005]瑰丽华尔兹 单调队列优化dp

    1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec  Memory Limit: 64 MBSubmit: 1802  Solved: 1097[Submit][Status ...

  5. 【BZOJ1499】[NOI2005]瑰丽华尔兹 单调队列+DP

    [BZOJ1499][NOI2005]瑰丽华尔兹 Description 你跳过华尔兹吗?当音乐响起,当你随着旋律滑动舞步,是不是有一种漫步仙境的惬意?众所周知,跳华尔兹时,最重要的是有好的音乐.但是 ...

  6. [Bzoj1499][NOI2005]瑰丽华尔兹[简单DP]

    1499: [NOI2005]瑰丽华尔兹 Time Limit: 3 Sec  Memory Limit: 64 MBSubmit: 1714  Solved: 1042[Submit][Status ...

  7. P2254 [NOI2005]瑰丽华尔兹

    链接P2254 [NOI2005]瑰丽华尔兹 首先有个很朴素的\(dp\),设\(f_{i,j,k}\)表示\(k\)时刻地点\(i,j\)的最长长度. 然后这样不能优化,考虑利用一段连续时间是同一个 ...

  8. 题解-[NOI2005]瑰丽华尔兹

    题解-[NOI2005]瑰丽华尔兹 [NOI2005]瑰丽华尔兹 \(n\times m\) 的矩阵.以 \((x,y)\) 为起点.一共 \(k\) 段时间,每段时间为 \([s_i,t_i](t_ ...

  9. BZOJ 1499 [NOI2005] 瑰丽华尔兹 | 单调队列优化DP

    BZOJ 1499 瑰丽华尔兹 | 单调队列优化DP 题意 有一块\(n \times m\)的矩形地面,上面有一些障碍(用'#'表示),其余的是空地(用'.'表示).每时每刻,地面都会向某个方向倾斜 ...

随机推荐

  1. idea下建立bootstrap项目

    环境准备: 1.创建一个static web名为bootstrapDemo 2.在bootstrapDemo文件夹下安装bower npm install bower 会自动产生node-module ...

  2. 关于/usr/bin/ld: cannot find -lcrypto 的错误

    Linux下 build code 时,要做 -lssl, -lcrypto 的链接,出现类似下面的错误: /usr/bin/ld: cannot find -lcrypto /usr/bin/ld: ...

  3. python whl包的安装

    1.首先安装PIP. https://pip.pypa.io/en/latest/installing.html#install-pip python get-pip.py 2.设置好环境变量: C: ...

  4. vector的内存分配机制分析

    该程序初步演示了我对vector在分配内存的时候的理解.可能有误差,随着理解的改变,改代码可以被修改. /* 功能说明: vector的内存分配机制分析. 代码说明: vector所管理的内存地址是连 ...

  5. 【java规则引擎】之Drools引擎中模拟ReteooStatefulSession内部设计结构

    该片文章只是抽取drools中java代码实现的一些代码结构,帮助我们理解drools是如何实现rete算法的. 该部分只是抽取ReteooStatefulSession工作过程中的代码架构 利用了多 ...

  6. JavaScript6 新语法 let 有什么优势

    最近看国外的前端代码时,发现ES6的新特性已经相当普及,尤其是 let,应用非常普遍 虽然 let 的用法与 var 相同,但不管是语法语义上,还是性能上,都提升了很多,下面就从这两方面对比一下 语法 ...

  7. BZOJ2724:[Violet 6]蒲公英

    浅谈分块:https://www.cnblogs.com/AKMer/p/10369816.html 题目传送门:https://lydsy.com/JudgeOnline/problem.php?i ...

  8. BZOJ3624:[APIO2008]免费道路

    浅谈并查集:https://www.cnblogs.com/AKMer/p/10360090.html 题目传送门:https://www.lydsy.com/JudgeOnline/problem. ...

  9. Azure RBAC管理ASM资源

    上一篇文章介绍了Azure基于ARM的RBAC,给不同的用户分配不同的权限. 但目前在国内使用的大部分用户还是以ASM的资源为主.比如:VM.Storage.Network.WebAPP.SQL Az ...

  10. laravel count的使用

    rt 学习源头: https://blog.csdn.net/chajinglong/article/details/51954010 四.聚合 查询构建器还提供了各种聚合方法,如统计,马克斯,min ...