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要求 ...
随机推荐
- 解决TOC与目录导航冲突问题
TOC是指markdown的TOC; 目录导航是指博客园中各个博主提供的各种目录导航. 现在改换markdown写博文了,我喜欢使用TOC作为目录,让大家了解博文的内容,也喜欢用"目录导航& ...
- 详解MongoDB中的多表关联查询($lookup)
一. 聚合框架 聚合框架是MongoDB的高级查询语言,它允许我们通过转换和合并多个文档中的数据来生成新的单个文档中不存在的信息. 聚合管道操作主要包含下面几个部分: 命令 功能描述 $projec ...
- lnmp环境里安装mssql及mssql的php扩展
小活中用到mssql,于是在自己lnmp环境中安装各mssql数据库 步骤如下: 源码编译安装 (1)下载freetds-stable-0.91源码:http://download.csdn.net/ ...
- OpenGL实例:三角形
OpenGL实例:三角形 作者:凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/ 更多请查看:计算机图形学 1. 三角形的旋转 #include <GL/ ...
- Spring类型转换(Converter)
Spring的类型转换 以前在面试中就有被问到关于spring数据绑定方面的问题,当时对它一直只是朦朦胧胧的概念,最近稍微闲下来有时间看了一下其中数据转换相关的内容,把相应的内容做个记录. 下面先说明 ...
- Installing Supervisor and Superlance on CentOS
Installing Supervisor1 and Superlance2 on CentOS/RHEL/Fedora can be a little tricky, as the versions ...
- maven-assembly-plugin打包可执行的jar包
pom.xml添加 <build> <plugins> <plugin> <artifactId>maven-assembly-plugin</a ...
- zabbix,php,nginx,mysql源码安装 神仙操作
→软件包 mkdir /soft/ cd /soft ♦下载以下软件包 nginx-1.14.2.tar.gz wget http://nginx.org/download/nginx-1.14.2. ...
- Spring Boot:The field file exceeds its maximum permitted size of 1048576 bytes
错误信息:The field file exceeds its maximum permitted size of 1048576 bytes原因是因为SpringBoot内嵌tomcat默认所能上传 ...
- Nero8刻录引导系统光盘镜像图文教程
刻录可引导的Windows系统光盘一直是电脑使用者较为需要的,今天,倡萌抽空写了这篇图文教程,希望对于菜鸟级的朋友有所帮助,大虾请飘过.本教程以最为强大的刻录软件Nero 8做为工具(其他版本的Ner ...