3537. 【NOIP2013提高组day2】华容道(搜索 + 剪枝)
Problem
给出一个类似华容道的图。\(q\)次询问,每次给你起始点,终止点,空格位置,让你求最少步数
\(n,m\le 30, q\le 500\).
Soultion
一道智障搜索题。
弱智想法最多80分。不用想了。我已经试过所有非O2的常数优化,还是有1.05秒。
考虑一下预处理。
事实上,我们发现只有当空格位置在初始点旁边时才会影响初始点(废话),所以我们可以先预处理在某一个点\((x,y)\)的四周,不经过这个点(x,y),到达这个点四周的最少步数。BFS解决。
然后每次询问时,就先把空格位置跑到初始点的四周,然后每次用预处理的去更新。
Code
#include <bits/stdc++.h>
#define I register int
#define F(i, a, b) for (I i = a; i <= b; i ++)
#define mem(a, b) memset(a, b, sizeof a)
const int N = 31;
const int dx[4] = { 1, 0 , 0, - 1};
const int dy[4] = { 0, - 1 , 1, 0};
using namespace std;
int h, t, Ans, ex, ey, sx, sy, tx, ty;
int n, m, q, a[N + 1][N + 1];
int f[N][N][4], bz[N][N][N][N], vis[N][N];
struct node {
int x, y, k;
} d[N * N * N];
struct Node {
int x, y;
} D[N * N];
void Doit() {
int st = 0, en = 0;
mem(f, 7), h = 0, D[t = 1] = {ex, ey}, mem(vis, 0), vis[ex][ey] = 1;
F(p, 0, 3) {
I xxx = ex + dx[p], yyy = ey + dy[p];
if (a[xxx][yyy] && xxx == sx && yyy == sy)
d[++ en] = {ex, ey, 3 - p}, f[ex][ey][3 - p] = 1;
}
while (h ++ < t) {
I x = D[h].x, y = D[h].y;
F(k, 0, 3) {
I xx = x + dx[k], yy = y + dy[k];
if (a[xx][yy] && !vis[xx][yy] && !(xx == sx && yy == sy)) {
vis[xx][yy] = vis[x][y] + 1, D[++ t] = {xx, yy};
F(p, 0, 3) {
I xxx = xx + dx[p], yyy = yy + dy[p];
if (a[xxx][yyy] && xxx == sx && yyy == sy)
d[++ en] = {xx, yy, 3 - p}, f[xx][yy][3 - p] = vis[xx][yy];
}
}
}
}
while (st ++ < en) {
I x = d[st].x, y = d[st].y, k = d[st].k;
F(p, 0, 3) {
I xx = x + dx[p], yy = y + dy[p];
if (a[xx][yy] && f[xx][yy][p] > f[x][y][k] + bz[x][y][k][3 - p]) {
f[xx][yy][p] = f[x][y][k] + bz[x][y][k][3 - p];
d[++ en] = {xx, yy, p};
}
}
}
int Ans = 1e8;
F(k, 0, 3)
Ans = min(Ans, f[tx][ty][k]);
printf("%d\n", Ans == 1e8 ? - 1 : Ans);
}
int main() {
scanf("%d%d%d", &n, &m, &q);
F(i, 1, n)
F(j, 1, m)
scanf("%d", &a[i][j]);
mem(bz, 7);
F(i, 1, n)
F(j, 1, m) {
if (!a[i][j]) continue;
F(k, 0, 3) {
int x = i + dx[k], y = j + dy[k], w = k;
if (!a[x][y]) continue;
h = 0, D[t = 1] = {x, y}, mem(vis, 0), bz[i][j][w][w] = 1, vis[x][y] = 1;
while (h ++ < t) {
x = D[h].x, y = D[h].y;
F(k, 0, 3) {
int xx = x + dx[k], yy = y + dy[k];
if (a[xx][yy] && !(xx == i && yy == j) && !vis[xx][yy]) {
vis[xx][yy] = vis[x][y] + 1, D[++ t] = {xx, yy};
F(k, 0, 3) {
int xxx = xx + dx[k], yyy = yy + dy[k];
if (a[xxx][yyy] && xxx == i && yyy == j)
bz[i][j][3 - w][k] = vis[xx][yy];
}
}
}
}
}
}
F(i, 1, q) {
scanf("%d%d%d%d%d%d", &ex, &ey, &sx, &sy, &tx, &ty);
if (sx == tx && sy == ty) {
puts("0");
continue;
}
Doit();
}
}
3537. 【NOIP2013提高组day2】华容道(搜索 + 剪枝)的更多相关文章
- NOIP2013 提高组day2 3 华容道 BFS
描述 小 B 最近迷上了华容道,可是他总是要花很长的时间才能完成一次.于是,他想到用编程来完成华容道:给定一种局面,华容道是否根本就无法完成,如果能完成,最少需要多少时间. 小 B 玩的华容道与经典的 ...
- 【华容道】题解(NOIP2013提高组day2)
分析 这道题很容易想到令f[x][y][x1][y1]表示空白块在(x,y).指定棋子在(x1,y1)时的最少步数,让空白块和四周的棋子交换,当空白块要和指定棋子交换时,把指定棋子移动,搞一下BFS就 ...
- NOIP2013 提高组 Day2
期望得分:100+100+30+=230+ 实际得分:100+70+30=200 T2 觉得题目描述有歧义: 若存在2i却不存在2i+1,自己按不合法做的,实际是合法的 T3 bfs 难以估分 虽然 ...
- NOIP2013提高组D2T3 华容道
n<=30 * m<=30 的地图上,0表示墙壁,1表示可以放箱子的空地.q<=500次询问,每次问:当空地上唯一没有放箱子的空格子在(ex,ey)时,把位于(sx,sy)的箱子移动 ...
- 洛谷P1979 [NOIP2013提高组Day2T3]华容道
P1979 华容道 题目描述 [问题描述] 小 B 最近迷上了华容道,可是他总是要花很长的时间才能完成一次.于是,他想到用编程来完成华容道:给定一种局面, 华容道是否根本就无法完成,如果能完成, 最少 ...
- 积木大赛 noip2013提高组day2
这道题一开始想到处理中间是0的位置,但这样时间太慢了,后来想到一种类似二分的方法,就是把这一段的最小值找到,全部减去最小值,然后有0一出现,就又递归处理前一段,每次答案就加上这一段的最小值: AC代码 ...
- NOIP2013 提高组day2 2 花匠 动规 找拐点 树状数组
花匠 描述 花匠栋栋种了一排花,每株花都有自己的高度.花儿越长越大,也越来越挤.栋栋决定把这排中的一部分花移走,将剩下的留在原地,使得剩下的花能有空间长大,同时,栋栋希望剩下的花排列得比较别致. 具体 ...
- Noip2013 提高组 Day2 T1 积木大赛
题目描述 春春幼儿园举办了一年一度的“积木大赛”.今年比赛的内容是搭建一座宽度为n的大厦,大厦可以看成由n块宽度为1的积木组成,第i块积木的最终高度需要是hi. 在搭建开始之前,没有任何积木(可以看成 ...
- [NOIP2013 提高组] 华容道 P1979 洛谷
[NOIP2013 提高组] 华容道 P1979 洛谷 强烈推荐,更好的阅读体验 经典题目:spfa+bfs+转化 题目大意: 给出一个01网格图,和点坐标x,y空格坐标a,b,目标位置tx,ty要求 ...
随机推荐
- MongoDB 在系统数据库local上无法创建用户的解决方法
我们知道,MongoDB的Oplog (operations log)记录了用户的最近一段时间的操作(时间长短主要受设置的oplogSize和程序的写入更新量的影响).那么,如果其他部门(例如BI团队 ...
- CSS优先级的及其衡量标准CSS权重
一.背景 CSS有三大特性:层叠性.继承性.优先级. 而我们在给CSS定义样式的时候,经常出现两个及以上的规则应用在同一元素上,单该元素最终在浏览器呈现的效果是应用的哪个规则呢?这就要考虑优先级的问题 ...
- spring boot 扫描不到自定义Controller
使用springboot启动类配置扫描的两种注解配置方式: 1.@Controller @EnableAutoConfiguration @ComponentScan 2.@SpringBoo ...
- Linux(Centos7)下搭建SVN服务器 (转载)
系统环境:centos7.2 第一步:通过yum命令安装svnserve,命令如下: yum -y install subversion 此命令会全自动安装svn服务器相关服务和依赖,安装完成会自动停 ...
- windows环境下安装yaf框架
windows环境下安装yaf框架 在windows下安装yaf框架 准备工作: php环境(过程略,wamp,xampp,phpstudy都行,php版本大于5.3) git工具(需要从github ...
- 使用superlance插件增强supervisor的监控能力
supervisor与superlance简介 supervisor是一款用python编写的进程监控.进程守护和进程管理的工具,可以工作在各种UNIX-like的操作系统上,通过简单的配置就可以启动 ...
- Linux系统中常见的目录名称以及相应内容
目录名称 应放置文件的内容 /boot 开机所需文件——内核.开机菜单以及所需配置文件等等 /dev 以文件形式存放任何设备与接口 /etc 配置文件 /home 用户家目录 /bin 存放单用户模式 ...
- 监控elssticSearch健康状态
[4ajr@elk1 scripts]$ curl 172.30.210.175:9200/_cat/health [4ajr@elk1 scripts]$ cat check_es_healthy. ...
- Chrome Inspect调试微信出现404,需要FQ
要么FQ,要么买个程序 见连接 http://www.cnblogs.com/slmk/p/7591126.html
- PHP命令执行与防范
命令执行漏洞是指攻击者可以随意执行系统命令,是高危漏洞之一. 命令连接符:& && || | 如:ping www.baidu.com && ne ...