Treasures and Vikings(两次搜索)
Treasures and Vikings
https://www.luogu.org/problemnew/show/P4668
题意翻译
你有一张藏宝图,藏宝图可视为 N×MN×M 的网格。每个格子可能是你的船、贼船、海、陆地或藏宝点。你只有一条船,整张图只有一条贼船。你和贼船都只能在海域移动。藏宝点在海中。
你与贼船交替移动,你移动一次+贼船移动一次算作一回合。每次移动,你可以移动到上下左右四个相邻格子中的一格,也可以不移动。贼船的移动同理,贼船也可以不移动。你先移动。
每一回合结束后,如果你和贼船在同一行或同一列,你就挂了;在你没挂的情况下,如果你位于藏宝点,你就拿到了宝藏。
请问:是否有一条安全的路径,使得无论贼船怎么跑你都能或者拿到宝藏。
Translated by @Planet6174
题目描述
You have a treasure map that is arranged into a N \times MN×M grid. A grid square may be either sea or part of an island. In addition, the map shows the treasure and an enemy Viking ship that occupies one (sea) square. Finally, for convenience you have also drawn your own position.
Now you must set up a fixed route to get the treasure. The route must start at your position, end at the treasure, and consist of a sequence of moves. In each move, you can go only to an (horizontally or vertically) adjacent square that is not part of an island. But beware: The Viking ship might follow you, using the same kind of moves! After each of your moves according to your route, the Viking ship may move or not. Your move and the Vikings’ reaction together is called a round.
After every round, the following checks are made:
- If you are in line with the Viking ship (you are in the same vertical or horizontal line as the Viking ship with only sea between the Viking ship and you), you are dead.
- If you aren’t dead and at the treasure-spot, you get the treasure.
Write a program that decides whether it is possible to set up a fixed route in advance such that you can get the treasure by following this route and will not get killed by the Vikings – no matter how the Viking ship moves.
输入输出格式
输入格式:
The first line of input contains two integers NN and MM, the dimensions of the map. Each of the following NN lines contain MM characters. Each character describes a square in the map, and is either .
(sea), I
(part of an island), V
(the Viking ship), Y
(your position), or T
(the treasure). Each of V
, Y
, and T
will occur exactly once.
输出格式:
The only line of the output must contain the string YES
, if it is possible to set up a route to get the treasure, or NO
otherwise.
输入输出样例
5 7
Y.....V
..I....
..IIIII
.......
...T...
YES
5 7
Y....V.
..I....
..IIIII
.......
...T...
NO
2 3
.YT
VII
NO
说明
Sample Explanation 1
The route is:go down for three times,go right for three times too,go down at last.
数据范围
对于 50\%50% 的数据,1 ≤ N,M ≤ 200 1≤N,M≤200。
对于所有数据,1≤N,M ≤ 700 1≤N,M≤700。
搜索出海盗船到每个点的最短路,在搜自己到每个点的最短路是否小于海盗船到每个点的最短路(洛谷开了氧气才过。。感觉有更厉害的搜索方法,但是没想出来。。)
// luogu-judger-enable-o2
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<string>
#include<algorithm>
#include<queue>
#include<vector>
using namespace std; char map[][];
int book[][];
int flag[][];
int n,m;
int yx,yy,vx,vy,tx,ty;
struct sair{
int x,y,step;
}; struct Step{
int x,y,step,num,dir;
}; int dir[][]={,,,-,,,-,}; void bfsV(){
sair s,e;
s.x=vx,s.y=vy,s.step=;
memset(book,-,sizeof(book));
queue<sair>Q;
Q.push(s);
flag[s.x][s.y]=;
book[s.x][s.y]=;
while(!Q.empty()){
s=Q.front();
Q.pop();
int co=;
int tmp=s.y+co;
while(tmp<m&&map[s.x][tmp]!='I'){
if(book[s.x][tmp]==-){
book[s.x][tmp]=s.step;
}
co++;
tmp=s.y+co;
}
co=-;
tmp=s.y+co;
while(tmp>=&&map[s.x][tmp]!='I'){
if(book[s.x][tmp]==-){
book[s.x][tmp]=s.step;
}
co--;
tmp=s.y+co;
}
co=;
tmp=s.x+co;
while(tmp<n&&map[tmp][s.y]!='I'){
if(book[tmp][s.y]==-){
book[tmp][s.y]=s.step;
}
co++;
tmp=s.x+co;
}
co=-;
tmp=s.x+co;
while(tmp>=&&map[tmp][s.y]!='I'){
if(book[tmp][s.y]==-){
book[tmp][s.y]=s.step;
}
co--;
tmp=s.x+co;
}
for(int i=;i<;i++){
e.x=s.x+dir[i][];
e.y=s.y+dir[i][];
if(e.x>=&&e.x<n&&e.y>=&&e.y<m&&map[e.x][e.y]!='I'&&!flag[e.x][e.y]){
flag[e.x][e.y]=;
e.step=s.step+;
Q.push(e);
}
}
}
} void bfsY(){
sair s,e;
queue<sair>Q;
s.x=yx,s.y=yy,s.step=;
Q.push(s);
memset(flag,,sizeof(flag));
while(!Q.empty()){
s=Q.front();
Q.pop();
for(int i=;i<;i++){
e.x=s.x+dir[i][];
e.y=s.y+dir[i][];
if(e.x>=&&e.y<n&&e.y>=&&e.y<m&&s.step<book[e.x][e.y]&&!flag[e.x][e.y]){
e.step=s.step+;
flag[e.x][e.y]=;
if(e.x==tx&&e.y==ty){
puts("YES");
return;
}
Q.push(e);
}
}
}
puts("NO");
} int main(){
scanf("%d %d%*c",&n,&m);
for(int i=;i<n;i++){
scanf("%s%*c",map[i]);
}
for(int i=;i<n;i++){
for(int j=;j<m;j++){
if(map[i][j]=='Y'){
yx=i,yy=j;
}
else if(map[i][j]=='V'){
vx=i,vy=j;
}
else if(map[i][j]=='T'){
tx=i,ty=j;
}
}
}
bfsV();
/* for(int i=0;i<n;i++){
for(int j=0;j<m;j++){
cout<<book[i][j]<<" ";
}
cout<<endl;
}*/
bfsY();
}
Treasures and Vikings(两次搜索)的更多相关文章
- iOS中的两种搜索方式UISearchDisplayController和UISearchController
大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 以前iOS的搜索一般都使用UISearchDisplayCon ...
- Java实现 LeetCode 581 最短无序连续子数组(从两遍搜索找两个指针)
581. 最短无序连续子数组 给定一个整数数组,你需要寻找一个连续的子数组,如果对这个子数组进行升序排序,那么整个数组都会变为升序排序. 你找到的子数组应是最短的,请输出它的长度. 示例 1: 输入: ...
- 使用Nominatim进行openstreetmap地址搜索/解析
Nominatim(来自拉丁语,意思是“名称”)是一个可以按名称和地址来搜索OSM中的数据,并生成OSM点的合成地址的工具(反向地理编码).可用在http://nominatim.openstreet ...
- Elasticsearch 数据搜索篇·【入门级干货】
ES即简单又复杂,你可以快速的实现全文检索,又需要了解复杂的REST API.本篇就通过一些简单的搜索命令,帮助你理解ES的相关应用.虽然不能让你理解ES的原理设计,但是可以帮助你理解ES,探寻更多的 ...
- 迷宫问题求解之“A*搜索”(二)
摘要:在迷宫问题求解之"穷举+回溯"(一)这篇文章中采用"穷举+回溯"的思想,虽然能从迷宫的入口到出口找出一条简单路径,但是找出来的不是最优路径.因此本文采用A ...
- linux 命令案例学习——文件搜索
两个搜索文件的工具 locate ——仅仅通过文件名查找文件 find ——依据文件的各种属性在既定目录(包括子目录)里查找 一个通常与文件搜索命令一起使用.处理搜索结果文件列表的命令 xa ...
- CodeForces 164A Variable, or There and Back Again 搜索
Variable, or There and Back Again 题目连接: http://codeforces.com/problemset/problem/164/A Description L ...
- Google搜索语法
原文:http://www.jianshu.com/p/37fe4f1381ef 前言 之前听过一个笑话,有人打开浏览器,输入www.baidu.com, 然后搜索框输入Google,查询google ...
- 第三代搜索推出网民评价系统,seo末日还会远吗?
昨天的360搜索可谓风光无限,两大搜索新品同日上线,至今360导航页面依旧飘荡着两者的身影,但是不少站长从此却是忧心忡忡,seo末日是否真的要到来了?笔者想起数日前写的一篇博文:seo末日言论频频来袭 ...
随机推荐
- 杂项-分布式-EDAS:深度解析阿里云EDAS服务
ylbtech-杂项-分布式-EDAS:深度解析阿里云EDAS服务 1.返回顶部 1. 深度解析阿里云EDAS服务 弹性伸缩 摘要: 第一种只适用于业务较少的情况,而在新业务不断增加的情况下,增加新应 ...
- python logging 日志模块的配置和使用
import logging logging.basicConfig(level=logging.DEBUG, format='%(asctime)s %(filename)s[line:%(line ...
- 解决Ubuntu下使用命令行subl 打开Sublime text3无法输入中文的问题
cd /opt/sublime_text/ sudo vim sub-fcitx.c 新建文件sub-fcitx.c,建议放在Sublime Text的所在目录下,将下面的代码复制进去 ,参考: ht ...
- java.lang.IllegalStateException: Fragment bb{42261900} not attached to Activity
A.处理异常java.lang.IllegalStateException: Fragment bb{42261900} not attached to Activity处理方式:由于在线程中调用Fr ...
- [UE4]C++创建对象的三种方式
#include <iostream> using namespace std; class A { private: int n; public: A(int m):n(m) { } ~ ...
- 关于Linux服务器磁盘空间占满问题的解决方法
下面给大家分享一篇关于Linux服务器磁盘占满问题解决方法(/dev/sda3 满了),需要的的朋友参考下吧 下面我们一起来看一篇关于Linux服务器磁盘占满问题解决(/dev/sda3 满了), ...
- crs_stop 错误一列
http://www.forzw.com/archives/703 grid 与 oracle 版本为11.2.0.4,为两节点RAC,在通过crs_stop -all命令关闭oracle服务时出 ...
- Python - Django - ORM 操作数据
查询数据(查询管理员): app01/models.py 中定义的类,也就是创建的表 from django.db import models # 类必须继承 models.Model class A ...
- 使用html和CSS进行网页网站设计 -- 简明步骤
网页制作流程: 1. 心中有规划,网站的骨架结构,页面布局layout. 2. 创建一个用于创建模板dwt的html页: main.html 3. 制作main.html: (1) 在html文件中依 ...
- 2. select下拉框获取选中的值
1.获取select选中的value值: $("#select1ID").find("option:selected").val(); --select1ID ...