RQNOJ 34 紧急援救
题目描述
话说2007年8月5日,Mike博士神秘失踪了,最后发现是被外星人绑架了,幸好外星人目前还是在地球上活动,并且知道外星人不了解地球,幸好,Milk博士身上有无线信号发送装置,我们终于确定了他的位置,必须赶快到那里去救他。
根据无线信号发送装置,我们确定出一张地图,为了尽快寻找到Mike博士,于是这个光荣和艰巨的任务便交给了你,编写程序,通过使用一张地图帮助研究所确定从研究所出发找到Mike博士最短距离。
数据范围: n<=1000
第一行为n
第二行为n*n的地图(其中0表示通路,1表示死路)
最后两行每行有两个数字,分别表示研究所的坐标和博士信号所在的位置。
一个数字k,表示从研究所出发找到Milk博士的最短距离。
裸宽搜。
BFS队列要开大,开50W拿了80分,悲伤
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
int mp[][];
bool vis[][];
char c[];
int n;
int sx,sy,tx,ty;
int mx[]={,,,-,},
my[]={,,,,-};
int BFS(){
int hd=,tl=;
int qx[],qy[],qans[];
qx[++tl]=sx;qy[tl]=sy;qans[tl]=;
vis[sx][sy]=;
while(hd<=tl){
for(int i=;i<=;i++){
int nx=mx[i]+qx[hd];
int ny=my[i]+qy[hd];
if(nx> && nx<=n && ny> && ny<=n &&
!vis[nx][ny] && !mp[nx][ny]){
vis[nx][ny]=;
qx[++tl]=nx;
qy[tl]=ny;
qans[tl]=qans[hd]+;
if(nx==tx && ny==ty){
return qans[tl];
}
}
}
hd++;
}
}
int main(){
scanf("%d",&n);
int i,j;
for(i=;i<=n;i++){
scanf("%s",c+);
for(j=;j<=n;j++){
mp[i][j]=c[j]-'';
}
}
scanf("%d%d%d%d",&sx,&sy,&tx,&ty);
printf("%d\n",BFS());
return ;
}
RQNOJ 34 紧急援救的更多相关文章
- 【TOJ 3692】紧急援救
		#include<iostream> #include<algorithm> #include<queue> using namespace std; #defin ... 
- PAT 甲级1003 Emergency (25)(25 分)(Dikjstra,也可以自己到自己!)
		As an emergency rescue team leader of a city, you are given a special map of your country. The map s ... 
- IoT之车联网
		一. 背景 这是一个笔者在实习公司策划的关于车联网的小项目,也是笔者参加某竞赛的作品<基于云平台的车内滞留儿童状况监测与处理>,本项目旨在为因各种原因导致儿童滞留车内热死.闷死的社会性事件 ... 
- [题解]RQNOJ PID87 过河
		链接:http://www.rqnoj.cn/problem/87 思路:动态规划 定义f[i][j]表示到达第 i 块给定石头用了 j 块添加石头的最少步数. 转移方程:f[i][j]=min{f[ ... 
- [题解]RQNOJ PID86 智捅马蜂窝
		链接:http://www.rqnoj.cn/problem/86 思路:单源点最短路 建图:首先根据父子关系连双向边,边权是距离/速度:再根据跳跃关系连单向边,边权是自由落体的时间(注意自由下落是一 ... 
- mysql-5.6.34 Installation from Source code
		Took me a while to suffer from the first successful souce code installation of mysql-5.6.34. Just pu ... 
- CSharpGL(34)以从零编写一个KleinBottle渲染器为例学习如何使用CSharpGL
		CSharpGL(34)以从零编写一个KleinBottle渲染器为例学习如何使用CSharpGL +BIT祝威+悄悄在此留下版了个权的信息说: 开始 本文用step by step的方式,讲述如何使 ... 
- C#开发微信门户及应用(34)--微信裂变红包
		在上篇随笔<C#开发微信门户及应用(33)--微信现金红包的封装及使用>介绍了普通现金红包的封装和使用,这种红包只能单独一次发给一个人,用户获取了红包就完成了,如果我们让用户收到红包后,可 ... 
- Git Stash紧急处理问题,需要切分支
		在开发过程中,大家都遇到过bug,并且有些bug是需要紧急修复的. 当开发人员遇到这样的问题时,首先想到的是我新切一个分支,把它修复了,再合并到master上. 当时问题来了,你当前正在开发的分支上面 ... 
随机推荐
- 根据html页面模板动态生成html页面(c#类)
			本文转载自:http://www.cnblogs.com/yuanbao/archive/2008/01/06/1027985.html点击打开链接 一直以为动态生成静态页面不好做,昨天在网上找了下, ... 
- yii2 的登录注册 轮子
			//利用到了yii2 框架之中的验证规则 进行判定而已 也不是很高深的东西 但是 使用框架自身的轮子 会有安全性能的隐患 1注册reg controller 中 我都以admin 为例子 publi ... 
- 图解HTTP总结(4)——返回结果的HTTP状态码
			HTTP状态码负责表示客户端HTTP请求的返回结果.标记服务器端的处理是否正常.通知出现的错误等工作. 状态码的类别 2XX 成功 200 OK 表示从客户端发来的请求在服务器端被正常处理了. 在响应 ... 
- 模块pandas
			python之pandas简单介绍及使用(一) https://www.cnblogs.com/misswangxing/p/7903595.html 
- strak组件(8):基本增删改查实现及应用和排序
			效果图: 新增函数: def reverse_common_url(self, name, *args, **kwargs) 反向生成url,需要传增删改的url作为参数,携带原参数 def reve ... 
- POJ:2367-Cleaning Shifts
			传送门:http://poj.org/problem?id=2376 Cleaning Shifts Time Limit: 1000MS Memory Limit: 65536K Total Sub ... 
- P2158 [SDOI2008]仪仗队 欧拉函数模板
			题目描述 作为体育委员,C君负责这次运动会仪仗队的训练.仪仗队是由学生组成的N * N的方阵,为了保证队伍在行进中整齐划一,C君会跟在仪仗队的左后方,根据其视线所及的学生人数来判断队伍是否整齐(如下图 ... 
- Json的用处一
			今天,我们用到了json的的用处,其实也就是一个很简单的用处,就是点击一个按钮,触发一个事件,然后调用json, 之后我们就可以进行异步操作,其实只是针对于后台的操作,其实我们并没有对数据库进行刷新, ... 
- BF算法(蛮力匹配算法)
			将主串M指定位置和目标串S开始位置进行对比,如果相同将M的下一个字符和S的下一个字符对比,如果不同则M的下一个字符和S的开始位置对比,直到S中每一个字符和M中的连续字符串相等,否则不匹配. C#代码- ... 
- centos 6.X 关闭selinux
			SELinux(Security-Enhanced Linux) 是美国国家安全局(NSA)对于强制访问控制的实现,是 Linux历史上最杰出的新安全子系统.在这种访问控制体系的限制下,进程只能访问那 ... 
