飞跃原野(三维bfs)
Problem Description
终于,法里奥来到了最后的一站:泰拉希尔原野,穿过这里就可以回到基地了。然而,敌人依然紧追不舍。不过,泰拉希尔的地理条件对法里奥十分有利,众多的湖泊随处分布。敌人需要绕道而行,但法里奥还是决定找一条能尽快回到基地的路。
假设泰拉希尔原野是一个m*n的矩阵,它有两种地形,P表示平,L表示湖泊,法里奥只能停留在平地上。他目前的位置在左上角(1,1)处,而目的地为右下角的(m,n)。法里奥可以向前后左右4个方向移动或飞行,每移动1格需要1单位时间。而飞行的时间主要花费在变形上,飞行本身时间消耗很短,所以无论一次飞行多远的距离,都只需要1单位时间。飞行的途中不能变向,并且一次飞行最终必须要降落到平地上。当然,由于受到能量的限制,法里奥不能无限制飞行,他总共最多可以飞行的距离为D。在知道了以上的信息之后,请你帮助法里奥计算一下,他最快到达基地所需要的时间。
Input
Output
Sample Input
4 4 2
PLLP
PPLP
PPPP
PLLP
Sample Output
5
Hint
Source
在bfs的基础上多出一维用来标记表示剩余的飞行距离
代码:
#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
#include<queue>
#include<stack>
#include<set>
#include<vector>
#include<map>
#include<cmath>
const int maxn=1e5+;
typedef long long ll;
using namespace std;
int n,m,d;
struct node
{
int x,y;
int step;
int left;
};
char Map[][];
int vis[][][];
int dir[][]={{,},{,-},{-,},{,}};
bool check(int x,int y)
{
if(x>=&&x<m&&y>=&&y<n)
{
return true;
}
else
{
return false;
}
}
int BFS(int x,int y )
{
node start ;
start.x=x;
start.y=y;
vis[x][y][d]=;
start.step=;
start.left=d;
queue<node>q;
q.push(start);
while(!q.empty())
{
node now;
now =q.front();
q.pop();
//cnt[now.x][now.y]=now.step;
if(now.x==m-&&now.y==n-)
{
return now.step;
}
for(int t=;t<;t++)
{
node next;
next.x=now.x+dir[t][];
next.y=now.y+dir[t][];
next.step=now.step+;
next.left=now.left;
if(check(next.x,next.y)&&vis[next.x][next.y][next.left]==&&Map[next.x][next.y]=='P')
{
vis[next.x][next.y][next.left]=;
q.push(next);
}
}
for(int t=;t<=d;t++)
{
node next;
next.x=now.x+;
next.y=now.y+t;
next.step=now.step+;
next.left=now.left-t;
if(check(next.x,next.y)&&vis[next.x][next.y][next.left]==&&Map[next.x][next.y]=='P'&&next.left>=)
{
vis[next.x][next.y][next.left]=;
q.push(next);
}
next.x=now.x+t;
next.y=now.y+;
next.step=now.step+;
next.left=now.left-t;
if(check(next.x,next.y)&&vis[next.x][next.y][next.left]==&&Map[next.x][next.y]=='P'&&next.left>=)
{
vis[next.x][next.y][next.left]=;
q.push(next);
}
next.x=now.x+;
next.y=now.y-t;
next.step=now.step+;
next.left=now.left-t;
if(check(next.x,next.y)&&vis[next.x][next.y][next.left]==&&Map[next.x][next.y]=='P'&&next.left>=)
{
vis[next.x][next.y][next.left]=;
q.push(next);
}
next.x=now.x-t;
next.y=now.y+;
next.step=now.step+;
next.left=now.left-t;
if(check(next.x,next.y)&&vis[next.x][next.y][next.left]==&&Map[next.x][next.y]=='P'&&next.left>=)
{
vis[next.x][next.y][next.left]=;
q.push(next);
}
}
}
return ;
}
int main()
{
cin>>m>>n>>d;
memset(vis,,sizeof(vis));
for(int t=;t<m;t++)
{
scanf("%s",Map[t]);
}
int ans=BFS(,);
if(!ans)
{
cout<<"impossible"<<endl;
return ;
}
cout<<ans<<endl;
return ;
}
飞跃原野(三维bfs)的更多相关文章
- AOJ.866 飞越原野 (三维BFS)
AOJ.866 飞越原野 (三维BFS) 题意分析 点我挑战题目 相比于普通的BFS,要多一维来记录当前剩余的体力.而且还要额外的一层循环来处理,飞过的路程. 代码总览 #include <io ...
- SDUT OJ 1124 飞越原野 (三维BFS练习)
飞跃原野 nid=24#time" title="C.C++.go.haskell.lua.pascal Time Limit5000ms Memory Limit 65536K ...
- SDUT 1124-飞跃荒野(三维BFS)
飞跃原野 Time Limit: 5000ms Memory limit: 65536K 有疑问?点这里^_^ 题目描写叙述 勇敢的法里奥出色的完毕了任务之后.正在迅速地向自己的基地撤退.但因为 ...
- hdu 1240:Asteroids!(三维BFS搜索)
Asteroids! Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total ...
- POJ 2251 Dungeon Master --- 三维BFS(用BFS求最短路)
POJ 2251 题目大意: 给出一三维空间的地牢,要求求出由字符'S'到字符'E'的最短路径,移动方向可以是上,下,左,右,前,后,六个方向,每移动一次就耗费一分钟,要求输出最快的走出时间.不同L层 ...
- POJ 2049— Finding Nemo(三维BFS)10/200
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/u013497151/article/details/29562915 海底总动员.... 这个题開始 ...
- POJ.2251 Dungeon Master (三维BFS)
POJ.2251 Dungeon Master (三维BFS) 题意分析 你被困在一个3D地牢中且继续寻找最短路径逃生.地牢由立方体单位构成,立方体中不定会充满岩石.向上下前后左右移动一个单位需要一分 ...
- hdu 1885 Key Task (三维bfs)
题目 之前比赛的一个题, 当时是崔老师做的,今天我自己做了一下.... 还要注意用bfs的时候 有时候并不是最先到达的就是答案,比如HDU 3442 这道题是要求最小的消耗血量伤害,但是并不是最先到 ...
- HDU 1885 Key Task(三维BFS)
题目链接 题意 : 出口不止一个,一共有四种颜色不同的门由大写字母表示,而钥匙则是对应的小写字母,当你走到门前边的位置时,如果你已经走过相应的钥匙的位置这个门就可以走,只要获得一把钥匙就可以开所有同颜 ...
随机推荐
- spring的IOC(反转控制)
Spring概念 1.1.1 spring 是什么 Spring 是分层的 Java SE/EE 应用 full-stack 轻量级开源框架,以 IoC(Inverse Of Control:反转控制 ...
- 提交项目到码云上git的使用
git clone .. cd 到项目目录 git branch 查看当前的所有分支 git branch shanshan 创建一个属于自己的分支 git checkout shansha ...
- 20、Java 泛型
1.晓之以理,动之以码 学Java就是很上头哦,一来直接三连问!!! 什么是泛型?为什么要用泛型?泛型怎么用? 当然泛型在Java中有很重要的一个地位,在面向对象编程以及在各种设计模式中有非常广泛的应 ...
- Vouch-proxy 实现 Zabbix4.4 对接 SSO
Vouch-proxy 实现 Zabbix 对接 SSO Zabbix 自身不支持 SSO 对接,我使用 Nginx 代理 Zabbix,将请求转发至 Vouch-proxy,由 Vouch-prox ...
- HRNet
- pandas | 详解DataFrame中的apply与applymap方法
本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是pandas数据处理专题的第5篇文章,我们来聊聊pandas的一些高级运算. 在上一篇文章当中,我们介绍了panads的一些计算方法, ...
- peewee的简单使用
peewee的简单使用 peewee是一个轻量级的ORM框架,peewee完全可以应对个人或企业的中小型项目的Model层,上手容易,功能强大. 一.安装peewee模块 使用pip命令工具安装pee ...
- YAML简要入门
这是一篇简单的YAML入门教程,目的是让你知晓什么YAML,以及YAML的基础语法.方便接下来学习如何使用Golang解析YAML.如果想获得更多YAML的知识,请查看http://yaml.org ...
- Redis设计与实现——独立功能的实现
发布和订阅 频道的订阅和退订 struct redisServer{ //键是被订阅者频道 ,键是一个链表,记录所有订阅这个频道的客户端 dict *publish_channels } 订阅实现: ...
- JDBC API阐述
JDBC API JDBC API 是一系列的接口,它使得应用程序能够进行数据库联接,执行SQL语句,并且得到返回结果. Driver 接口 Java.sql.Driver 接口是所有 JDBC 驱动 ...