[NOI 2005]瑰丽华尔兹
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]瑰丽华尔兹的更多相关文章
- DP+单调队列 codevs 1748 瑰丽华尔兹(还不是很懂具体的代码实现)
codevs 1748 瑰丽华尔兹 2005年NOI全国竞赛 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 大师 Master 题解 题目描述 Descripti ...
- 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\)时走的最多的步数 这样子每一步要么停要么走 时 ...
- BZOJ 1499 [NOI2005] 瑰丽华尔兹 | 单调队列优化DP
BZOJ 1499 瑰丽华尔兹 | 单调队列优化DP 题意 有一块\(n \times m\)的矩形地面,上面有一些障碍(用'#'表示),其余的是空地(用'.'表示).每时每刻,地面都会向某个方向倾斜 ...
- luogu P2254 [NOI2005]瑰丽华尔兹
题目链接 luogu P2254 [NOI2005]瑰丽华尔兹 题解 为什么我我我不放放放bzoj的链接呢? 因为打的暴力啊,然后bzojT了呀QAQQQQQ(逃 然后luogu竟然过了呀呀呀 dp[ ...
- 【DP】【单调队列】【NOI2005】瑰丽华尔兹
340. [NOI2005] 瑰丽华尔兹 ★★★ 输入文件:adv1900.in 输出文件:adv1900.out 简单对照 时间限制:1 s 内存限制:128 MB [任务描写叙述] 你跳过华尔兹吗 ...
- 【BZOJ1499】[NOI2005]瑰丽华尔兹 单调队列+DP
[BZOJ1499][NOI2005]瑰丽华尔兹 Description 你跳过华尔兹吗?当音乐响起,当你随着旋律滑动舞步,是不是有一种漫步仙境的惬意?众所周知,跳华尔兹时,最重要的是有好的音乐.但是 ...
随机推荐
- 请描述一下 cookies,sessionStorage 和 localStorage 的区别
原文:http://blog.csdn.net/lxcao/article/details/52809939 相同点:都存储在客户端不同点: 1.存储大小 cookie数据大小不能超过4k. sess ...
- Python短文本自动识别个体是否有自杀倾向【新手必学】
我们以微博树洞为例,讲解了怎么自动爬取单个微博的评论.今天我们就要用上这些数据做一个自杀倾向分类器,这样的分类器如果应用得当,将可以帮助成千上万误入歧途的人们挽回生命. 为了简化问题,我们将短文本分为 ...
- [代码记录] C语言链表
#开始 · 简单的创建链表 #代码 #include<conio.h> #include<stdio.h> #include<stdlib.h> struct St ...
- HTML-移动端-rem px vw vh 的转换
vw/vh rem px 三者的转换(快速入门移动端页面编写) 1:三种单位的转换 2:如何适配移动端的不同设备 前提知识: 手机端的长宽是实际设计过程中的两倍 比如手机端是 750 * 1200 那 ...
- P1478
昨天花一下午时间,把 codeblocks 代码 highlight 改了改,感觉还不错 :) 咳咳.还是说题吧. 这道题利用贪心思想,先去除所有够不着的,然后按使用力气 $ y_i $ 从小到大排序 ...
- linux 开启普通用户sudo root权限操作获取免密
root 身份登陆 $ visudo然后进入修改配置找到 root ALL=(ALL) ALL 在下面增加: yourusername ALL=(ALL) NOPASSWD: ALL ex ...
- SpringBoot基于数据库的定时任务实现
在我们平时开发的项目中,定时任务基本属于必不可少的功能,那大家都是怎么做的呢?但我知道的大多都是静态定时任务实现. 基于注解来创建定时任务非常简单,只需几行代码便可完成.实现如下: @Configur ...
- TreeGrid分页树形表格
先展示效果图: 加载treegrid的json数据格式有两种: (1)基本的数据结构 [{ , "name":"C", "size":&qu ...
- laravel 语言包拓展
laravel 使用make:auth生成用户认证,登录表单是英文版本的,打开模板文件(resources/views/auth/login.blade.php),此模板文件是我们刚刚使用 make: ...
- redis的使用1
学Linux已经将近一个月了,Linux中讲到的redis的使用,到现在还不回具体的使用在php中,今天周末,于是想把redis的使用搞懂. 网上的资料不算多,但还需要硬着头皮学.其中找到这样一篇关于 ...