Descrption

有一些矩形障碍,碰到障碍会停下,求从一个点到另一个点的最少移动步数.

Sol

BFS.

因为题目的特殊性质,两个矩形没有任何相邻,起始点和终点和矩形没有相邻.

所以从一个点的移动只有 左/右 或 上/下两种可能,与它到该点的方向不同,不然就又移动回去了.

然后可以在边BFS的时候边建图,往上/下 或 左/右 找能限制住他的矩阵.

复杂度 \(O(n^2)\)

Code

/**************************************************************
Problem: 2541
User: BeiYu
Language: C++
Result: Accepted
Time:148 ms
Memory:1420 kb
****************************************************************/ #include<cstdio>
#include<queue>
#include<iostream>
using namespace std; const int N = 4050;
const int INF = 1e9; int n,sx,sy,tx,ty;
int x1[N],y1[N],x2[N],y2[N],vis[N<<2];
struct S{ int r,x,y,d; };
queue< S > q;
//U 0 D 1 L 2 R 3 inline int in(int x=0,char ch=getchar(),int v=1){
while(ch!='-' && (ch>'9' || ch<'0')) ch=getchar();if(ch == '-') v=-1,ch=getchar();
while(ch>='0' && ch<='9') x=(x<<3)+(x<<1)+ch-'0',ch=getchar();return x*v; }
int main(){
n=in(),sx=in(),sy=in(),tx=in(),ty=in();
for(int i=1;i<=n;i++) x1[i]=in(),y1[i]=in(),x2[i]=in(),y2[i]=in();
for(q.push((S){ 0,sx,sy,0 }),q.push((S){ 1,sx,sy,0 });!q.empty();){
int mx=-INF,mi=INF,p1=0,p2=0;
int rr=q.front().r,xx=q.front().x,yy=q.front().y,dd=q.front().d;
q.pop();
if(rr){//Move to Up/Down
for(int i=1;i<=n;i++) if(x1[i]<=xx && xx<=x2[i]){
if(y1[i]>yy && y1[i]<mi) mi=y1[i],p1=i;
if(y2[i]<yy && y2[i]>mx) mx=y2[i],p2=i;
}
if(p1 && !vis[p1<<2]) vis[p1<<2]=1,q.push((S){ 0,xx,mi-1,dd+1 });
if(p2 && !vis[p2<<2|1]) vis[p2<<2|1]=1,q.push((S){ 0,xx,mx+1,dd+1 });
if(xx==tx && mx<=ty && ty<=mi) return printf("%d\n",dd+1),0;
}else{//Move to Left/Right
for(int i=1;i<=n;i++) if(y1[i]<=yy && yy<=y2[i]){
if(x1[i]>xx && x1[i]<mi) mi=x1[i],p1=i;
if(x2[i]<xx && x2[i]>mx) mx=x2[i],p2=i;
}
if(p1 && !vis[p1<<2|2]) vis[p1<<2|2]=1,q.push((S){ 1,mi-1,yy,dd+1 });
if(p2 && !vis[p2<<2|3]) vis[p2<<2|3]=1,q.push((S){ 1,mx+1,yy,dd+1 });
if(yy==ty && mx<=tx && tx<=mi) return printf("%d\n",dd+1),0;
}
}return printf("%d\n",0),0;
}

  

BZOJ 2541: [Ctsc2000]冰原探险的更多相关文章

  1. [Ctsc2000]冰原探险

    Description 传说中,南极有一片广阔的冰原,在冰原下藏有史前文明的遗址.整个冰原被横竖划分成了很多个大小相等的方格.在这个冰原上有N个大小不等的矩形冰山,这些巨大的冰山有着和南极一样古老的历 ...

  2. [题目] Luogu P3716 [CTSC2000]冰原探险

    题面 题目背景 传说中,南极有一片广阔的冰原,在冰原下藏有史前文明的遗址.整个冰原被横竖划分成了很多个大小相等的方格.在这个冰原上有N个大小不等的矩形冰山,这些巨大的冰山有着和南极一样古老的历史,每个 ...

  3. 【[CTSC2000]冰原探险】

    noip前练一下码力还是非常有前途的 这道题本来就是想写个大暴力弃疗的,所以直接强上暴力浑身舒爽 结果发现要不是判重的时候脑残了,就能\(A\)了 没什么好说的呀,就是每一次都暴力\(O(n)\)往上 ...

  4. 【BZOJ 2541】【Vijos 1366】【CTSC 2000】冰原探险

    http://www.lydsy.com/JudgeOnline/problem.php?id=2541 https://vijos.org/p/1366 loli秘制大爆搜_(:з」∠)_坑了好久啊 ...

  5. BZOJ 2246 [SDOI2011]迷宫探险 (记忆化搜索)

    题目大意:太长了,略 bzoj luogu 并没有想到三进制状压 题解: 3进制状压陷阱的状态,0表示这种陷阱的状态未知,1已知危险,2已知不危险 然后预处理出在当前状态下,每种陷阱有害的概率,设为$ ...

  6. BZOJ.2246.[SDOI2011]迷宫探险(DP 记忆化搜索 概率)

    题目链接 求最大的存活概率,DP+记忆化. 用f[s][x][y][hp]表示在s状态,(x,y)点,血量为hp时的存活概率. s是个三进制数,记录每个陷阱无害/有害/未知. 转移时比较容易,主要是在 ...

  7. 【刷题】BZOJ 2539 [Ctsc2000]丘比特的烦恼

    Description 随着社会的不断发展,人与人之间的感情越来越功利化.最近,爱神丘比特发现,爱情也已不再是完全纯洁的了.这使得丘比特很是苦恼,他越来越难找到合适的男女,并向他们射去丘比特之箭.于是 ...

  8. BZOJ 2539: [Ctsc2000]丘比特的烦恼

    Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 695  Solved: 260[Submit][Status][Discuss] Description ...

  9. BZOJ 2246 [SDOI2011]迷宫探险 ——动态规划

    概率DP 记忆化搜索即可,垃圾数据,就是过不掉最后一组 只好打表 #include <cstdio> #include <cstring> #include <iostr ...

随机推荐

  1. Servlet之Filter详解

    参考文献:http://www.cnblogs.com/zlbx/p/4888312.html Filter,过滤器,顾名思义,即是对数据等的过滤,预处理过程.为什么要引入过滤器呢?在平常访问网站的时 ...

  2. Google

    1. Google Play: Google Play是谷歌官方的的应用市场, Google Play 服务通常会在 Android 装置上自动更新. http://baike.baidu.com/l ...

  3. MySQL笔记-最简单的方法来解决找不到mysqld.sock文件的问题

    首先,环境:ubuntu 14.04,采用apt-get的方式安装的,手动安装可能路径设置稍有区别. 1.安装MySQL后,用命令行首次启动时发现找不到Mysqld.sock文件,提示: ERROR ...

  4. C# 6.0可能的新特性

    C# 6.0可能的新特性 1.主构造函数(Primary Constructors) 主构造函数给类中的变量赋值 Before public class Point { private int x, ...

  5. Autofac.Integration.Mvc分析

    Autofac.Integration.Mvc static ILifetimeScope LifetimeScope { get { return (ILifetimeScope)HttpConte ...

  6. java中跳出if判断

    今天学到的一点儿新东西一个if判断里面有好多东西,紧接着还有其他代码,不能使用return来结束这个if判断这时候,就需要这样: out:if (!"null".equals(re ...

  7. _SYS_LIB="-lm -lnsl -ldl"

    -lm  是指连接libm.so     意思是连接数学库, -lnsl  如果涉及RPC编程,必然需要libnsl.so,因此必须在编译选项里加入 -lnsl.      gcc 编译选项 -L是要 ...

  8. smarty string_format用法 取小数点后2位

    <{if $d.ul_pv}> <{$d.sum/$d.ul_pv|string_format:'%.2f'}> <{else}> 0.00 <{/if}&g ...

  9. c++模板

    1.从 python 说起 def add(a, b): return a + b; print add(3.1, 5.1); #8.2 print add("abc", &quo ...

  10. Android布局属性大全

    RelativeLayout http://wenku.baidu.com/view/2e39724333687e21af45a97e.html?from=related&hasrec=1 h ...