题目:

7-1 拯救007 (30 分)

在老电影“007之生死关头”(Live and Let Die)中有一个情节,007被毒贩抓到一个鳄鱼池中心的小岛上,他用了一种极为大胆的方法逃脱 —— 直接踩着池子里一系列鳄鱼的大脑袋跳上岸去!(据说当年替身演员被最后一条鳄鱼咬住了脚,幸好穿的是特别加厚的靴子才逃过一劫。)

设鳄鱼池是长宽为100米的方形,中心坐标为 (0, 0),且东北角坐标为 (50, 50)。池心岛是以 (0, 0) 为圆心、直径15米的圆。给定池中分布的鳄鱼的坐标、以及007一次能跳跃的最大距离,你需要告诉他是否有可能逃出生天。

输入格式:

首先第一行给出两个正整数:鳄鱼数量 N(≤100)和007一次能跳跃的最大距离 D。随后 N 行,每行给出一条鳄鱼的 (x,y) 坐标。注意:不会有两条鳄鱼待在同一个点上。

输出格式:

如果007有可能逃脱,就在一行中输出"Yes",否则输出"No"。

输入样例 1:

14 20
25 -15
-25 28
8 49
29 15
-35 -2
5 28
27 -29
-8 -28
-20 -35
-25 -20
-13 29
-30 15
-35 40
12 12

输出样例 1:

Yes

输入样例 2:

4 13
-12 12
12 12
-12 -12
12 -12

输出样例 2:

No

分析:

1. 首先这看上去是一道图的题目,但实际上是不需要将整个图给存储起来也能够完成题目的要求(当然存起来也可以做),

只需要利用好题目所给的坐标就可了!

2. 值得注意的一点是虽然 N(≤100),但如果化为直观图的话,这是一个 101 * 101 的一个矩阵。

3. 拯救007在这里用DFS和BFS都能够解决,这里采用了BFS算法,下面是整道题的思路:

①从池心岛边缘开始,将能够一步到达的坐标(鳄鱼的位置)入队

记作A集合(红点所示)

②A集合中任意选一个点a(队列首元素出队实现)

判断a点能否一步逃离鳄鱼池:

(1)如果可以,输出 Yes 结束程序

(2)如果不可以,从a开始,将能够一步到达的坐标入队,直至A中所有元素遍历完成。

记作B集合(红点所示)

③B集合重复A集合操作。

循环结束条件:(1)找到符合条件的坐标,输出Yes

(2)遍历所有坐标,无符合条件的,输出No


代码:

 #include<iostream>
#include<cstring>
#include<cmath>
#include<queue>
using namespace std; #define max 101 typedef struct point{
int x, y;//坐标(x,y)
double dis;//点point到圆心(0,0)距离
}point; int visit[max] = {};//全局变量visit[],记录该坐标是否被访问过
void input(point *p, int n);
void BFS(point *p, int n, int step); int main(){
int n, step;
cin>>n>>step; point p[max];
memset(p, , sizeof(p));
input(p, n); //若一步就可以跨出去
if(step >= -7.5){
cout<<"Yes";
}else BFS(p, n, step);//不能一步就跨出去的话 return ;
} //输入函数:输入数据
void input(point *p, int n)
{
for(int i=; i<n; i++){
cin>>p[i].x>>p[i].y;//输入鳄鱼的坐标
p[i].dis = sqrt(p[i].x*p[i].x + p[i].y*p[i].y) - 7.5;//计算并存储鳄鱼到池心岛的最近距离
}
} //层次遍历
void BFS(point *p, int n, int step)
{
//先将第一步能够够得着的坐标入队列
queue<point> qu;
for(int i=; i<n; i++){
if(p[i].dis<=step){
qu.push(p[i]);
visit[i] = ;
}
} while(qu.size() != ){
//判断出队的点A下一步能不能够跨出去
point mark = qu.front();
if(mark.x+step >= || mark.x-step <= - || mark.y+step >= || mark.y-step <=-){
cout<<"Yes";
return;
}
qu.pop(); // A点下一步能够够得着的点入队
for(int i=; i<n; i++){
if(visit[i] != && sqrt((mark.x-p[i].x)*(mark.x-p[i].x) + (mark.y-p[i].y)*(mark.y-p[i].y)) <= step){
qu.push(p[i]);
//入队标记
visit[i] = ;
}
}
} cout<<"No"; }

总结:

拯救007这个题目是一道很好的拓展眼界的题目吧,刚接触这道题的时候会被课本的知识限制住了想象空间,

总觉得做图的题目都要先将图给存储起来,才好做下一步的操作。

还是学的太少,被自己的知识绊住了脚步。

:D 加油!

利用BFS解决拯救007问题 -- 数据结构的更多相关文章

  1. [LeetCode] BFS解决的题目

    一.130  Surrounded Regions(https://leetcode.com/problems/surrounded-regions/description/) 题目: 解法: 这道题 ...

  2. 有关dfs、bfs解决迷宫问题的个人见解

    可以使用BFS或者DFS方法解决的迷宫问题! 题目如下: kotori在一个n*m迷宫里,迷宫的最外层被岩浆淹没,无法涉足,迷宫内有k个出口.kotori只能上下左右四个方向移动.她想知道有多少出口是 ...

  3. 利用闭包解决for循环里onclick事件不能捕捉实时i值问题

    问题描述 我们都知道,如果我们对于一组元素(相同的标签)同时进行onclick事件处理的时候(在需要获取到索引的时候),一般是写一个for循环,但是onclick是一个异步调用的,所以会带来一个问题, ...

  4. 利用Readability解决网页正文提取问题

    分享: 利用Readability解决网页正文提取问题   做数据抓取和分析的各位亲们, 有没有遇到下面的难题呢? - 如何从各式各样的网页中提取正文!? 虽然可以用SS为各种网站写脚本做解析, 但是 ...

  5. 利用BFS求最短路

    利用BFS求图的最短路, POJ3984 #define _CRT_SECURE_NO_DEPRECATE #include<iostream> #include<string.h& ...

  6. 利用gulp解决微信浏览器缓存问题

    做了好多项目,这次终于要解决微信浏览器缓存这个令人头疼的问题了.每次上传新的文件,在微信浏览器中访问时,总要先清除微信的缓存,实在麻烦,在网上搜罗了很多解决办法,终于找到了方法:利用gulp解决缓存问 ...

  7. 利用Json_encode解决中文问题

    利用Json_encode解决中文问题       public function return_json($data=array()){         echo json_encode($data ...

  8. 利用Filter解决跨域请求的问题

    1.为什么出现跨域. 很简单的一句解释,A系统中使用ajax调用B系统中的接口,此时就是一个典型的跨域问题,此时浏览器会出现以下错误信息,此处使用的是chrome浏览器. 错误信息如下: jquery ...

  9. 利用NSProxy解决NSTimer内存泄漏问题

    之前写过一篇利用RunTime解决由NSTimer导致的内存泄漏的文章,最近和同事讨论觉得这样写有点复杂,然后发现有NSProxy这么好用的根类,根类,根类,没错NSProxy与NSObject一样是 ...

随机推荐

  1. POJ 2456 编程技巧之------二分查找思想的巧妙应用

    Aggressive cows Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 18599   Accepted: 8841 ...

  2. win10 + cuda10.0 + pytorch1.2 + CenterNet 环境搭建

    心血来潮,想跑个 CenterNet 检测瞅瞅...麻蛋,有非官方层 一.下载好 CenterNet 源码 https://github.com/xingyizhou/CenterNet 二.注意你需 ...

  3. HDU 6089 Rikka with Terrorist (线段树)

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=6089 题解 这波强行维护搞得我很懵逼... 扫描线,只考虑每个点能走到左上方(不包括正上方,但包括正左 ...

  4. [VIJOS2053][SDOI2019]世界地图:最小生成树+虚树

    分析 可以发现第一列和最后一列永远不会被删除,于是我们可以想到维护前后缀最小生成树,但是直接维护的话显然时间空间两爆炸.(通过上网找题解)可以发现我们关心的只是最左边和最右边两列,而不关心内部的连边情 ...

  5. d3.js+svg的树形图

    效果图 数据 { "name":"中国", "children": [ { "name":"浙江" ...

  6. Java基础教程免费分享

    这是我自己早前听课时整理的Java全套知识,适用于初学者,也可以适用于中级进阶的人,你们可以下载,我认为是比较系统全面的,可以抵得上市场上90%的学习资料.讨厌那些随便乱写的资料还有拿出来卖钱的人!在 ...

  7. 【转】Java操作CSV文件导入导出

    特别提示:本人博客部分有参考网络其他博客,但均是本人亲手编写过并验证通过.如发现博客有错误,请及时提出以免误导其他人,谢谢!欢迎转载,但记得标明文章出处:http://www.cnblogs.com/ ...

  8. webpack 最新版

    之前说过老的版本,webpack@3.8.1 这个版本,现在我们来看看,新版本和老版本的区别 webpack 4 以上的版本 npm 全称 node package manager (node 包管理 ...

  9. 异步上传&预览图片-压缩图片

    移动端普及的时代,流量是用户最关心的,手机拍出来的照片基本上都在1~2M以上,这样上传会非常耗流量,影响用户体验,此例能在保证清晰度的情况下,将4.5M的图片压缩为30K <!DOCTYPE h ...

  10. SAP MaxDB日常运维—启动、关闭、磁盘扩容

    SAP MaxDB日常维护1.检查MaxDB状态,并启动su - pe0csccd /sapdb/SDB/db/bin./dbmcli -d SDB -u superdba,Mypassword db ...