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 VY, 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.

输入输出样例

输入样例#1:

5 7
Y.....V
..I....
..IIIII
.......
...T...
输出样例#1:

YES
输入样例#2:

5 7
Y....V.
..I....
..IIIII
.......
...T...
输出样例#2:

NO
输入样例#3:

2 3
.YT
VII
输出样例#3:

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(两次搜索)的更多相关文章

  1. iOS中的两种搜索方式UISearchDisplayController和UISearchController

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 以前iOS的搜索一般都使用UISearchDisplayCon ...

  2. Java实现 LeetCode 581 最短无序连续子数组(从两遍搜索找两个指针)

    581. 最短无序连续子数组 给定一个整数数组,你需要寻找一个连续的子数组,如果对这个子数组进行升序排序,那么整个数组都会变为升序排序. 你找到的子数组应是最短的,请输出它的长度. 示例 1: 输入: ...

  3. 使用Nominatim进行openstreetmap地址搜索/解析

    Nominatim(来自拉丁语,意思是“名称”)是一个可以按名称和地址来搜索OSM中的数据,并生成OSM点的合成地址的工具(反向地理编码).可用在http://nominatim.openstreet ...

  4. Elasticsearch 数据搜索篇·【入门级干货】

    ES即简单又复杂,你可以快速的实现全文检索,又需要了解复杂的REST API.本篇就通过一些简单的搜索命令,帮助你理解ES的相关应用.虽然不能让你理解ES的原理设计,但是可以帮助你理解ES,探寻更多的 ...

  5. 迷宫问题求解之“A*搜索”(二)

    摘要:在迷宫问题求解之"穷举+回溯"(一)这篇文章中采用"穷举+回溯"的思想,虽然能从迷宫的入口到出口找出一条简单路径,但是找出来的不是最优路径.因此本文采用A ...

  6. linux 命令案例学习——文件搜索

    两个搜索文件的工具 locate  ——仅仅通过文件名查找文件 find     ——依据文件的各种属性在既定目录(包括子目录)里查找 一个通常与文件搜索命令一起使用.处理搜索结果文件列表的命令 xa ...

  7. CodeForces 164A Variable, or There and Back Again 搜索

    Variable, or There and Back Again 题目连接: http://codeforces.com/problemset/problem/164/A Description L ...

  8. Google搜索语法

    原文:http://www.jianshu.com/p/37fe4f1381ef 前言 之前听过一个笑话,有人打开浏览器,输入www.baidu.com, 然后搜索框输入Google,查询google ...

  9. 第三代搜索推出网民评价系统,seo末日还会远吗?

    昨天的360搜索可谓风光无限,两大搜索新品同日上线,至今360导航页面依旧飘荡着两者的身影,但是不少站长从此却是忧心忡忡,seo末日是否真的要到来了?笔者想起数日前写的一篇博文:seo末日言论频频来袭 ...

随机推荐

  1. java study文件读写

    文件读写 如果在代码中写入大量的数据,会增加代码的冗余度,通过读取文件的方式,可以精简代码,便于数据的修改和代码的维护 IO流的分类:字节流和字符流 字符流 字符输出流:写文本文件的,抽象基类java ...

  2. Nginx Tengine ngx_http_upstream_check_module 健康功能检测使用

    该模块可以为Tengine提供主动式后端服务器健康检查的功能. 该模块在Tengine-1.4.0版本以前没有默认开启,它可以在配置编译选项的时候开启:./configure --with-http_ ...

  3. 【Codeforces】CF 165 E Compatible Numbers(状压dp)

    题目 传送门:QWQ 分析 很难想到方向,但有方向了就很easy了. 我们如何减少不必要的计算? 如果我们知道了$ 100111 $的相容的数,$ 100101 $的相容数和他是完全一样的. 我们就靠 ...

  4. CentOS 7.3 CDH 5.10.0 Druid0.12.4安装记录

    CentOS 7.3 CDH 5.10.0安装记录 0. 集群规划192.167.1.247 realtime247 realtime+hadoopdata192.167.1.248 broker24 ...

  5. while_else

    使用while循环输出100-50,从大到小,到50的时候,再从0到50输出,然后结束count =

  6. VFS文件系统结构分析

    VFS是Linux非常核心的一个概念,linux下的大部分操作都要用到VFS的相关功能.这里从使用者的角度,对VFS进行了简单说明.使用者不但需要知道Linux下有哪些文件操作的函数,还需要对VFS的 ...

  7. CentOS 6.4 i386 版本安装 FastDFS、使用Nginx作为文件访问WEB服务器

    安装环境:1. CentOS-6.4-i3862. FastDFS_v4.063. fastdfs-nginx-module_v1.154. Nginx-1.5.6(安装见此)5. libevent- ...

  8. 基于Redis位图实现用户签到功能

    场景需求 适用场景如签到送积分.签到领取奖励等,大致需求如下: 签到1天送1积分,连续签到2天送2积分,3天送3积分,3天以上均送3积分等. 如果连续签到中断,则重置计数,每月初重置计数. 当月签到满 ...

  9. django-插件django REST framework,返回序列化的数据

    官网: http://www.django-rest-framework.org 1.安装 pip install djangorestframework 2.在setting.py中注册app 中添 ...

  10. leetcode130

    struct POS { int x; int y; POS(int newx, int newy): x(newx), y(newy) {} }; class Solution { public: ...