【BZOJ 2541】【Vijos 1366】【CTSC 2000】冰原探险
http://www.lydsy.com/JudgeOnline/problem.php?id=2541
https://vijos.org/p/1366
loli秘制大爆搜_(:з」∠)_坑了好久啊QAQ一上午花了2h+写这道题,最后WA了2个点,调了一下午多。
在矩形一条边上的所有位置都是等效的,所以把每个矩形的四条边拆开,表示为点。每个点只会连出去一条边,暴力找边建图,最后跑堆优dij。
时间复杂度\(O(n^2)\)(附带大常数16一脸不可过?不过最后竟然过了)

一开始认为有环爆搜不可做,便建图跑了最短路。后来xyx0711跟我说直接bfs不走环,因为正确的路不会走环,后来想想也是。。。但是懒得改了。

恶心经历:冰块一次推进洞真心没想到,改完之后还WA第8个点,后来发现判断和T的连边时少写了一个条件,快速写上过了那个点,再评测发现第一个点突然又WA了,查了好久发现因为之前写得太急把坐标打反了(坐标打反了都能放过我9个点,这数据。。。)
改第8个点改了一下午TWT,自己画了一下原图,还手动模拟出了正确答案QAQ

起点是最左上角的点,终点是最靠右边的点,这个是离散过坐标轴后画出来的图
真心代码题

#include<queue>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int in() {
int k = 0, fh = 1; char c = getchar();
for (; c < '0' || c > '9'; c = getchar())
if (c == '-') fh = -1;
for (; c >= '0' && c <= '9'; c = getchar())
k = k * 10 + c - 48;
return k * fh;
}
const int N = 4003;
const int jie[4][2] = {3, 1, 2, 0, 3, 1, 2, 0};
int n, xs, xt, ys, yt, xa[N], ya[N], xb[N], yb[N], num[N][4], to[N][4][2], tot = 0, l, r, up, tt[4];
struct node {int nxt, to;} E[N * 4 * 2 + 100];
int cnt = 0, point[N * 4], dist[N * 4], S, T;
bool inq[N * 4];
void ins(int u, int v) {E[++cnt] = (node) {point[u], v}; point[u] = cnt;}
struct Qnode {
int id, dist;
Qnode (int _id = 0, int _dist = 0) : id(_id), dist(_dist) {}
bool operator < (const Qnode &A) const {
return dist > A.dist;
}
};
priority_queue <Qnode> Q;
int main() {
n = in(); xs = in(); ys = in(); xt = in(); yt = in();
for (int i = 1; i <= n; ++i) {
xa[i] = in();
ya[i] = in();
xb[i] = in();
yb[i] = in();
for (int j = 0; j < 4; ++j)
num[i][j] = ++tot;
}
if (xs == xt) {
l = ys; r = yt;
if (l > r) swap(l, r);
up = 0;
for (int i = 1; i <= n; ++i)
if (yb[i] < l || ya[i] > r || xa[i] > xs || xb[i] < xs)
++up;
if (up == n) {puts("1"); return 0;}
}
if (ys == yt) {
l = xs; r = xt;
if (l > r) swap(l, r);
up = 0;
for (int i = 1; i <= n; ++i)
if (yb[i] < ys || ya[i] > ys || xa[i] > r || xb[i] < l)
++up;
if (up == n) {puts("1"); return 0;}
}
for (int i = 1; i <= n; ++i) {
l = ya[i]; r = yb[i]; up = xa[i];
for (int j = 1; j <= n; ++j)
if (xb[j] < up) {
if (l <= ya[j] - 1 && ya[j] - 1 <= r) {
if ((to[j][1][1] == 0) || (xa[to[j][1][1]] > up))
to[j][1][1] = i;
}
if (l <= yb[j] + 1 && yb[j] + 1 <= r) {
if ((to[j][3][1] == 0) || (xa[to[j][3][1]] > up))
to[j][3][1] = i;
}
}
l = xa[i]; r = xb[i]; up = ya[i];
for (int j = 1; j <= n; ++j)
if (yb[j] < up) {
if (l <= xa[j] - 1 && xa[j] - 1 <= r) {
if ((to[j][0][1] == 0) || (ya[to[j][0][1]] > up))
to[j][0][1] = i;
}
if (l <= xb[j] + 1 && xb[j] + 1 <= r) {
if ((to[j][2][1] == 0) || (ya[to[j][2][1]] > up))
to[j][2][1] = i;
}
}
l = ya[i]; r = yb[i]; up = xb[i];
for (int j = 1; j <= n; ++j)
if (xa[j] > up) {
if (l <= ya[j] - 1 && ya[j] - 1 <= r) {
if ((to[j][1][0] == 0) || (xb[to[j][1][0]] < up))
to[j][1][0] = i;
}
if (l <= yb[j] + 1 && yb[j] + 1 <= r) {
if ((to[j][3][0] == 0) || (xb[to[j][3][0]] < up))
to[j][3][0] = i;
}
}
l = xa[i]; r = xb[i]; up = yb[i];
for (int j = 1; j <= n; ++j)
if (ya[j] > up) {
if (l <= xa[j] - 1 && xa[j] - 1 <= r) {
if ((to[j][0][0] == 0) || (yb[to[j][0][0]] < up))
to[j][0][0] = i;
}
if (l <= xb[j] + 1 && xb[j] + 1 <= r) {
if ((to[j][2][0] == 0) || (yb[to[j][2][0]] < up))
to[j][2][0] = i;
}
}
}
for (int i = 1; i <= n; ++i)
for (int j = 0; j < 4; ++j)
for (int k = 0; k < 2; ++k)
if (to[i][j][k])
ins(num[i][j], num[to[i][j][k]][jie[j][k]]);
S = ++tot; T = ++tot;
int x = xs, y = ys;
for (int i = 1; i <= n; ++i) {
if (xa[i] > x && ya[i] <= y && y <= yb[i]) {
if ((tt[0] == 0) || (xa[i] < xa[tt[0]]))
tt[0] = i;
}
if (ya[i] > y && xa[i] <= x && x <= xb[i]) {
if ((tt[1] == 0) || (ya[i] < ya[tt[1]]))
tt[1] = i;
}
if (xb[i] < x && ya[i] <= y && y <= yb[i]) {
if ((tt[2] == 0) || (xb[i] > xb[tt[2]]))
tt[2] = i;
}
if (yb[i] < y && xa[i] <= x && x <= xb[i]) {
if ((tt[3] == 0) || (yb[i] > yb[tt[3]]))
tt[3] = i;
}
}
for (int i = 0; i < 4; ++i)
if (tt[i]) ins(S, num[tt[i]][i]);
x = xt; y = yt;
for (int i = 1; i <= n; ++i) {
if (xa[i] - 1 == x) {
if (y < ya[i] && ((to[i][0][0] == 0 && ya[i] > y) || (to[i][0][0] != 0 && yb[to[i][0][0]] < y)))
ins(num[i][0], T);
if (y > yb[i] && ((to[i][0][1] == 0 && yb[i] < y) || (to[i][0][1] != 0 && ya[to[i][0][1]] > y)))
ins(num[i][0], T);
}
if (ya[i] - 1 == y) {
if (x < xa[i] && ((to[i][1][0] == 0 && xa[i] > x) || (to[i][1][0] != 0 && xb[to[i][1][0]] < x)))
ins(num[i][1], T);
if (x > xb[i] && ((to[i][1][1] == 0 && xb[i] < x) || (to[i][1][1] != 0 && xa[to[i][1][1]] > x)))
ins(num[i][1], T);
}
if (xb[i] + 1 == x) {
if (y < ya[i] && ((to[i][2][0] == 0 && ya[i] > y) || (to[i][2][0] != 0 && yb[to[i][2][0]] < y)))
ins(num[i][2], T);
if (y > yb[i] && ((to[i][2][1] == 0 && yb[i] < y) || (to[i][2][1] != 0 && ya[to[i][2][1]] > y)))
ins(num[i][2], T);
}
if (yb[i] + 1 == y) {
if (x < xa[i] && ((to[i][3][0] == 0 && xa[i] > x) || (to[i][3][0] != 0 && xb[to[i][3][0]] < x)))
ins(num[i][3], T);
if (x > xb[i] && ((to[i][3][1] == 0 && xb[i] < x) || (to[i][3][1] != 0 && xa[to[i][3][1]] > x)))
ins(num[i][3], T);
}
}
memset(dist, 127, sizeof(dist));
dist[S] = 0;
Q.push(Qnode(S, 0));
Qnode u;
while (!Q.empty()) {
u = Q.top(); Q.pop();
if (inq[u.id]) continue;
inq[u.id] = true;
for (int i = point[u.id]; i; i = E[i].nxt)
if (dist[u.id] + 1 < dist[E[i].to]) {
dist[E[i].to] = dist[u.id] + 1;
Q.push(Qnode(E[i].to, dist[E[i].to]));
}
}
printf("%d\n", dist[T] == dist[0] ? 0 : dist[T]);
return 0;
}
【BZOJ 2541】【Vijos 1366】【CTSC 2000】冰原探险的更多相关文章
- BZOJ 2541: [Ctsc2000]冰原探险
Descrption 有一些矩形障碍,碰到障碍会停下,求从一个点到另一个点的最少移动步数. Sol BFS. 因为题目的特殊性质,两个矩形没有任何相邻,起始点和终点和矩形没有相邻. 所以从一个点的移动 ...
- [Ctsc2000]冰原探险
Description 传说中,南极有一片广阔的冰原,在冰原下藏有史前文明的遗址.整个冰原被横竖划分成了很多个大小相等的方格.在这个冰原上有N个大小不等的矩形冰山,这些巨大的冰山有着和南极一样古老的历 ...
- BZOJ 1411&&Vijos 1544 : [ZJOI2009]硬币游戏【递推,快速幂】
1411: [ZJOI2009]硬币游戏 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 897 Solved: 394[Submit][Status ...
- [题目] Luogu P3716 [CTSC2000]冰原探险
题面 题目背景 传说中,南极有一片广阔的冰原,在冰原下藏有史前文明的遗址.整个冰原被横竖划分成了很多个大小相等的方格.在这个冰原上有N个大小不等的矩形冰山,这些巨大的冰山有着和南极一样古老的历史,每个 ...
- bzoj:1221;vijos 1552 软件开发
Description 某软件公司正在规划一项n天的软件开发计划,根据开发计划第i天需要ni个软件开发人员,为了提高软件开发人员的效率,公司给软件人员提供了很多的服务,其中一项服务就是要为每个开发人员 ...
- bzoj 1084;vijos 1191 [SCOI2005] 最大子矩阵
Description 这里有一个n*m的矩阵,请你选出其中k个子矩阵,使得这个k个子矩阵分值之和最大.注意:选出的k个子矩阵不能相互重叠. Input 第一行为n,m,k(1≤n≤100,1≤m≤2 ...
- 【[CTSC2000]冰原探险】
noip前练一下码力还是非常有前途的 这道题本来就是想写个大暴力弃疗的,所以直接强上暴力浑身舒爽 结果发现要不是判重的时候脑残了,就能\(A\)了 没什么好说的呀,就是每一次都暴力\(O(n)\)往上 ...
- 【BZOJ 1146】【CTSC 2008】网络管理network
一句话题意,树链上带改动区间第k大 感觉能够dfs+主席树O(nlog2n)过掉,但我不会写= = 于是写的线段树套平衡树+链剖+二分(改动O(nlog3n),查询O(nlog4n)慢了好多啊QAQ) ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
随机推荐
- Android M Permission 运行时权限 学习笔记
Android M Permission 运行时权限 学习笔记 从Android 6.0开始, 用户需要在运行时请求权限, 本文对运行时权限的申请和处理进行介绍, 并讨论了使用运行时权限时新老版本的一 ...
- C#中的泛型
写在前面:好几个月没更新了,这些天换了份工作,原来的公司出了很多事所以辞职了.这篇文章写的超级好,让我终于明白了困扰在我心里好久的C#泛型的概念,不仅收藏了,还手动转发一下 哈哈哈~ 1.1 C#中的 ...
- GCD
Grand Central Dispatch(GCD)包含语言特点.运行库和系统增强功能,它提供系统的.综合的改进,进而去支持并发代码在iOS和OSX多核硬件上的执行. 子系统.CoreFoundat ...
- 详解tintColor属性
tintColor属性是iOS7之后新加的一个属性,这个属性定义了一个非默认的着色颜色值,其值的设置会影响到以视图为根视图的整个视图层次结构.它主要是改变控件的颜色,以获取一些有意思的视觉效果. ti ...
- 【Swift】UILabel 设置内边距
前言 对应一个曾经开发 Android 的人来说,没有这些基础属性简直令人发指,还是表喷这个,认真写代码 - - # 声明 欢迎转载,但请保留文章原始出处:) 博客园:http://www.cnblo ...
- android gradle NDK简介
本章介绍在Android开发中,关于NDK,gradle相关的知识点. 1.NDK简介 (1)NDK是一系列工具的集合 NDK提供了一系列的工具,帮助开发者快速开发C(或C++)的动态库,并能自动将s ...
- 如何在 ASP.NET 4.6 与 IIS10 中运用 HTTP/2 ?
在过去十年中,Web 技术已经取得了种种进展.从基本的 HTML 开始,网页发展出更丰富的外观和感觉,变得更加直观,对用户更加友好并且越来越大放异彩.这些变化的关键贡献来自于一些新的和翻新技术,且借力 ...
- 欢迎进入MyKTV点歌系统展示
一个项目,一分收获:一个项目,一些资源.Ktv项目也是一样的,所以我想分享我的收获,让你们获得你需要的资源. 一. 那MyKTV点歌系统具体的功能有哪些呢?我们就来看看吧! 1.MyKTV前台功能: ...
- ORACLE参数max_shared_servers空值与零的区别
ORACLE数据库中的参数max_shared_servers,这是一个DBA很熟悉的参数,但是这个参数max_shared_servers为空值与为0有区别吗?这个细节可能很多人都没有注意过.如下所 ...
- MySQL 复制表
MySQL 复制表 如果我们需要完全的复制MySQL的数据表,包括表的结构,索引,默认值等. 如果仅仅使用CREATE TABLE ... SELECT 命令,是无法实现的. 本文将为大家介绍如何完整 ...