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. 请描述一下 cookies,sessionStorage 和 localStorage 的区别

    原文:http://blog.csdn.net/lxcao/article/details/52809939 相同点:都存储在客户端不同点: 1.存储大小 cookie数据大小不能超过4k. sess ...

  2. Python短文本自动识别个体是否有自杀倾向【新手必学】

    我们以微博树洞为例,讲解了怎么自动爬取单个微博的评论.今天我们就要用上这些数据做一个自杀倾向分类器,这样的分类器如果应用得当,将可以帮助成千上万误入歧途的人们挽回生命. 为了简化问题,我们将短文本分为 ...

  3. [代码记录] C语言链表

    #开始 · 简单的创建链表 #代码 #include<conio.h> #include<stdio.h> #include<stdlib.h> struct St ...

  4. HTML-移动端-rem px vw vh 的转换

    vw/vh rem px 三者的转换(快速入门移动端页面编写) 1:三种单位的转换 2:如何适配移动端的不同设备 前提知识: 手机端的长宽是实际设计过程中的两倍 比如手机端是 750 * 1200 那 ...

  5. P1478

    昨天花一下午时间,把 codeblocks 代码 highlight 改了改,感觉还不错 :) 咳咳.还是说题吧. 这道题利用贪心思想,先去除所有够不着的,然后按使用力气 $ y_i $ 从小到大排序 ...

  6. linux 开启普通用户sudo root权限操作获取免密

    root 身份登陆 $ visudo然后进入修改配置找到 root    ALL=(ALL) ALL 在下面增加: yourusername ALL=(ALL)   NOPASSWD:  ALL ex ...

  7. SpringBoot基于数据库的定时任务实现

    在我们平时开发的项目中,定时任务基本属于必不可少的功能,那大家都是怎么做的呢?但我知道的大多都是静态定时任务实现. 基于注解来创建定时任务非常简单,只需几行代码便可完成.实现如下: @Configur ...

  8. TreeGrid分页树形表格

    先展示效果图: 加载treegrid的json数据格式有两种: (1)基本的数据结构 [{ , "name":"C", "size":&qu ...

  9. laravel 语言包拓展

    laravel 使用make:auth生成用户认证,登录表单是英文版本的,打开模板文件(resources/views/auth/login.blade.php),此模板文件是我们刚刚使用 make: ...

  10. redis的使用1

    学Linux已经将近一个月了,Linux中讲到的redis的使用,到现在还不回具体的使用在php中,今天周末,于是想把redis的使用搞懂. 网上的资料不算多,但还需要硬着头皮学.其中找到这样一篇关于 ...