Description

题库链接

给你一张 \(n\times m\) 的棋盘,棋盘上有一些障碍。一共 \(t\) 个时刻,被分为 \(k\) 段,在每一段中都有一个向上/下/左/右倾斜的趋势(持续时间 \(q_i\))。

1 时刻一架钢琴在 \((x_0,y_0)\) 处,你可以在任意时刻控制它动或不动,若动则该时刻会向趋势方向滑动一格。要求在任何时刻都不能出棋盘或碰到障碍,问你 \(t\) 时刻内最多滑动多少格。

\(1\leq n,m,k\leq 200\)

Solution

设 \(f_{i,x,y}\) 为第 \(i\sim k\) 个时段 \(i\) 时段初始时候在 \((x,y)\) 处的最小花费。则答案为 \(f_{1,x_0,y_0}\)。

假设第 \(i\) 个时段向左滑,那么 \(f_{i,x,y}=\max\limits_{x-a\leq q_i}f_{i+1,a,y}+x-a\),其中 \((a,y)\sim(x,y)\) 中无障碍。

容易发现 \(a\) 是可以用单调队列优化的。

其余方向同理。总复杂度 \(O(nmk)\)。

Code

#include <bits/stdc++.h>
using namespace std;
const int N = 205; int n, m, x, y, k, mp[N][N], s[N], t[N], d[N], f[2][N][N], id;
int q[N], head, tail;
char ch[N]; void work1(int j) {
head = 1, tail = 0;
for (int i = 1; i <= n; i++) {
if (mp[i][j]) {head = 1, tail = 0; continue; }
while (head <= tail && f[0][q[tail]][j]-q[tail] < f[0][i][j]-i) --tail;
q[++tail] = i;
while (i-q[head] > t[id]) ++head;
f[1][i][j] = f[0][q[head]][j]+i-q[head];
}
}
void work2(int j) {
head = 1, tail = 0;
for (int i = n; i >= 1; i--) {
if (mp[i][j]) {head = 1, tail = 0; continue; }
while (head <= tail && f[0][q[tail]][j]+q[tail] < f[0][i][j]+i) --tail;
q[++tail] = i;
while (q[head]-i > t[id]) ++head;
f[1][i][j] = f[0][q[head]][j]+q[head]-i;
}
}
void work3(int i) {
head = 1, tail = 0;
for (int j = 1; j <= m; j++) {
if (mp[i][j]) {head = 1, tail = 0; continue; }
while (head <= tail && f[0][i][q[tail]]-q[tail] < f[0][i][j]-j) --tail;
q[++tail] = j;
while (j-q[head] > t[id]) ++head;
f[1][i][j] = f[0][i][q[head]]+j-q[head];
}
}
void work4(int i) {
head = 1, tail = 0;
for (int j = m; j >= 1; j--) {
if (mp[i][j]) {head = 1, tail = 0; continue; }
while (head <= tail && f[0][i][q[tail]]+q[tail] < f[0][i][j]+j) --tail;
q[++tail] = j;
while (q[head]-j > t[id]) ++head;
f[1][i][j] = f[0][i][q[head]]+q[head]-j;
}
}
int main() {
scanf("%d%d%d%d%d", &n, &m, &x, &y, &k);
for (int i = 1; i <= n; i++) {
scanf("%s", ch+1);
for (int j = 1; j <= m; j++) mp[i][j] = ch[j] == 'x';
}
for (int i = 1; i <= k; i++) scanf("%d%d%d", &s[i], &t[i], &d[i]), t[i] = t[i]-s[i]+1;
for (id = k; id >= 1; id--) {
memcpy(f[0], f[1], sizeof(f[0]));
memset(f[1], 0, sizeof(f[0]));
if (d[id] == 1) for (int i = 1; i <= m; i++) work1(i);
else if (d[id] == 2) for (int i = 1; i <= m; i++) work2(i);
else if (d[id] == 3) for (int i = 1; i <= n; i++) work3(i);
else if (d[id] == 4) for (int i = 1; i <= n; i++) work4(i);
}
printf("%d\n", f[1][x][y]);
return 0;
}

[NOI 2005]瑰丽华尔兹的更多相关文章

  1. DP+单调队列 codevs 1748 瑰丽华尔兹(还不是很懂具体的代码实现)

    codevs 1748 瑰丽华尔兹 2005年NOI全国竞赛  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 大师 Master 题解       题目描述 Descripti ...

  2. NOI2005瑰丽华尔兹

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

  3. 【BZOJ1499】瑰丽华尔兹(动态规划)

    [BZOJ1499]瑰丽华尔兹(动态规划) 题面 BZOJ 题解 先写部分分 设\(f[t][i][j]\)表示当前在\(t\)时刻,位置在\(i,j\)时走的最多的步数 这样子每一步要么停要么走 时 ...

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

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

  5. 【BZOJ1499】【NOI2005】瑰丽华尔兹(动态规划)

    [BZOJ1499]瑰丽华尔兹(动态规划) 题面 BZOJ 题解 先写部分分 设\(f[t][i][j]\)表示当前在\(t\)时刻,位置在\(i,j\)时走的最多的步数 这样子每一步要么停要么走 时 ...

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

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

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

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

  8. 【DP】【单调队列】【NOI2005】瑰丽华尔兹

    340. [NOI2005] 瑰丽华尔兹 ★★★ 输入文件:adv1900.in 输出文件:adv1900.out 简单对照 时间限制:1 s 内存限制:128 MB [任务描写叙述] 你跳过华尔兹吗 ...

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

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

随机推荐

  1. Centos6.10-FastDFS-Storage-Nginx配置

    nginx+fastdfs-nginx-module 安装此处省略. 1.进入工作目录 cd /usr/local/nginx/conf 2.创建子目录 mkdir configs 3.创建stora ...

  2. Django 生成数据库表时的报错TypeError: __init__() missing 1 required positional argument: 'on_delete'

    原因及解决办法: https://www.cnblogs.com/phyger/p/8035253.html

  3. 解决tensorflow Saver.restore()无效的问题

    解决tensorflow 的 Saver.restore()无法从本地读取变量的问题 最近做tensorflow 手写数字识别的时候遇到了一个问题,Saver的restore()方法无法从本地恢复变量 ...

  4. js判断json对象是否包含key

    if(json.hasOwnProperty("KEY")){ }

  5. Cygwin不能编译及解决办法

    最近不知道什么原因,以前使用cygwin编译Android动态库,现在不能使用了,报下面的错误. Android NDK: Host 'awk' tool is outdated. Please de ...

  6. pycharm如何关闭虚拟环境(即取消venv命令行)

    venv命令行 是虚拟环境特有, 为什么要使用虚拟环境: 在实际项目开发中,我们通常会根据自己的需求去下载各种相应的框架库,如Scrapy.Beautiful Soup等,但是可能每个项目使用的框架库 ...

  7. Java的单例模式(singleton)

    为什么需要单例?只因为国家的独生子女政策(当然现在可以生2个) 单例是一个很孤独的物种,因为它的类里面做多只有也仅只有它一个. 常见的是懒汉及饿汉模式, 1.懒汉,为什么这么叫,看看英文,原为lazy ...

  8. 「JSOI2013」游戏中的学问

    「JSOI2013」游戏中的学问 传送门 考虑 \(\text{DP}\) 设 \(dp_{i, j}\) 表示将前 \(i\) 个人分成 \(j\) 个集合,并且第 \(i\) 个人在第 \(j\) ...

  9. 学习JavaScript数据结构与算法---前端进阶系列

    学习建议 1.视频学习---认知 建议:在中国慕课上找"数据结构"相关的视频教程.中国大学MOOC 推荐清华大学.北京大学.浙江大学的教程,可先试看,然后根据自身的情况选择视频进行 ...

  10. hive3.1.1 hive-site.xml

    <property> <name>hive.metastore.warehouse.dir</name> <value>/data/hive/wareh ...