飞跃原野

Time Limit: 5000ms   Memory limit: 65536K  有疑问?点这里^_^

题目描写叙述

勇敢的法里奥出色的完毕了任务之后。正在迅速地向自己的基地撤退。但因为后面有着一大群追兵,所以法里奥要尽快地返回基地,否则就会被敌人逮住。



最终。法里奥来到了最后的一站:泰拉希尔原野,穿过这里就能够回到基地了。

然而,敌人依旧紧追不舍。

只是,泰拉希尔的地理条件对法里奥十分有利,众多的湖泊随处分布。

敌人须要绕道而行,但法里奥还是决定找一条能尽快回到基地的路。

 

如果泰拉希尔原野是一个m*n的矩阵,它有两种地形,P表示平,L表示湖泊,法里奥仅仅能停留在平地上。他眼下的位置在左上角(1,1)处,而目的地为右下角的(m,n)。法里奥能够向前后左右4个方向移动或飞行,每移动1格须要1单位时间。而飞行的时间主要花费在变形上,飞行本身时间消耗非常短,所以不管一次飞行多远的距离,都仅仅须要1单位时间。飞行的途中不能变向,而且一次飞行终于必须要降落到平地上。当然,因为受到能量的限制,法里奥不能无限制飞行,他总共最多能够飞行的距离为D。

在知道了以上的信息之后,请你帮助法里奥计算一下,他最快到达基地所须要的时间。

输入

第一行是3个整数,m(1≤m≤100),n(1≤n≤100)。D(1≤D≤100)。表示原野是m*n的矩阵。法里奥最多仅仅能飞行距离为D。接下来的m行每行有n个字符。相互之间没有空格。P表示当前位置是平地,L则表示湖泊。假定(1。1)和(m,n)一定是平地。

输出

一个整数,表示法里奥到达基地须要的最短时间。假设无法到达基地,则输出impossible。

演示样例输入

4 4 2
PLLP
PPLP
PPPP
PLLP

演示样例输出

5

QAQ用二维的bfs怒搜8个方向就是过不去。Wjj说是要状态同步仅仅能用三维,sad 还是对三维比較不敏感,没往那方面想。
这道题,以行和列为x。y,以飞行距离D为z 建立三维搜索思想,然后每次在4个方向分别让它行走和飞行。其它的没什么了。
#include <cstdio>//BFS
#include <iostream>
#include <cstring>
#include <algorithm>
#include <queue>
using namespace std;
char ma[110][110];
bool vis[110][110][110];
typedef struct node
{
int x,y,d,time;
};
int n,m,d;
int dir[4][2]={{0,1},{0,-1},{1,0},{-1,0}};
void bfs()
{
queue <node> Q;
node t;int i,j;
t.x=0;t.y=0;t.time=0;t.d=d;
Q.push(t);
while(!Q.empty())
{
node v=Q.front(); Q.pop();
if(v.x==m-1&&v.y==n-1)
{
cout<<v.time<<endl;
return ;
}
for(i=0;i<4;i++)
{
t.x=v.x+dir[i][0];
t.y=v.y+dir[i][1];
t.d=v.d;
if(t.x>=0&&t.x<m&&t.y>=0&&t.y<n&&!vis[t.x][t.y][t.d]&&ma[t.x][t.y]=='P')//run
{
vis[t.x][t.y][t.d]=1;
t.time=v.time+1;
Q.push(t);
}
for(j=2;j<=v.d;j++)//fly
{
t.x=v.x+j*dir[i][0];
t.y=v.y+j*dir[i][1];
if(t.x>=0&&t.x<m&&t.y>=0&&t.y<n&&!vis[t.x][t.y][v.d-j]&&ma[t.x][t.y]=='P')
{
vis[t.x][t.y][v.d-j]=1;
t.d=v.d-j;
t.time=v.time+1;
Q.push(t);
}
}
}
}
puts("impossible");
}
int main()
{
int i,j;
while(cin>>m>>n>>d)
{
memset(vis,0,sizeof(vis));
for(i=0;i<m;i++)
cin>>ma[i];
bfs();
}
return 0;
}


版权声明:本文博客原创文章,博客,未经同意,不得转载。

SDUT 1124-飞跃荒野(三维BFS)的更多相关文章

  1. 飞跃原野(三维bfs)

    Problem Description 勇敢的法里奥出色的完成了任务之后,正在迅速地向自己的基地撤退.但由于后面有着一大群追兵,所以法里奥要尽快地返回基地,否则就会被敌人逮住. 终于,法里奥来到了最后 ...

  2. SDUT OJ 1124 飞越原野 (三维BFS练习)

    飞跃原野 nid=24#time" title="C.C++.go.haskell.lua.pascal Time Limit5000ms Memory Limit 65536K ...

  3. hdu 1240:Asteroids!(三维BFS搜索)

    Asteroids! Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total ...

  4. POJ 2251 Dungeon Master --- 三维BFS(用BFS求最短路)

    POJ 2251 题目大意: 给出一三维空间的地牢,要求求出由字符'S'到字符'E'的最短路径,移动方向可以是上,下,左,右,前,后,六个方向,每移动一次就耗费一分钟,要求输出最快的走出时间.不同L层 ...

  5. POJ 2049— Finding Nemo(三维BFS)10/200

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/u013497151/article/details/29562915 海底总动员.... 这个题開始 ...

  6. POJ.2251 Dungeon Master (三维BFS)

    POJ.2251 Dungeon Master (三维BFS) 题意分析 你被困在一个3D地牢中且继续寻找最短路径逃生.地牢由立方体单位构成,立方体中不定会充满岩石.向上下前后左右移动一个单位需要一分 ...

  7. AOJ.866 飞越原野 (三维BFS)

    AOJ.866 飞越原野 (三维BFS) 题意分析 点我挑战题目 相比于普通的BFS,要多一维来记录当前剩余的体力.而且还要额外的一层循环来处理,飞过的路程. 代码总览 #include <io ...

  8. hdu 1885 Key Task (三维bfs)

    题目 之前比赛的一个题, 当时是崔老师做的,今天我自己做了一下.... 还要注意用bfs的时候  有时候并不是最先到达的就是答案,比如HDU 3442 这道题是要求最小的消耗血量伤害,但是并不是最先到 ...

  9. HDU 1885 Key Task(三维BFS)

    题目链接 题意 : 出口不止一个,一共有四种颜色不同的门由大写字母表示,而钥匙则是对应的小写字母,当你走到门前边的位置时,如果你已经走过相应的钥匙的位置这个门就可以走,只要获得一把钥匙就可以开所有同颜 ...

随机推荐

  1. 在Windows基础上(硬盘)安装Linux操作系统(CentOS/RedHat)

    注:该方法安装CentOS ,RedHat均没有问题,其它Linux操作系统,没有尝试过. 0.创建一个fat32的盘.我分了8G给这个盘,盘符为F.F盘以后的内存所有删除,作为未分配的内存.这个留用 ...

  2. [INS-32052] Oracle基文件夹和Oracle主文件夹位置同样

    1.错误描写叙述 [INS-32052] Oracle基文件夹和Oracle主文件夹位置同样 2.错误原因    Oracle基文件夹和Oracle主文件夹位置同样 3.解决的方法    Oracle ...

  3. 【C++探索之旅】第一部分第二课:C++编程的必要软件

    内容简介 1.第一部分第二课:C++编程的必要软件 2.第一部分第三课预告:第一个C++程序 C++编程的必要软件 经过上一课之后,大家是不是摩拳擦掌,准备大干一场了呢. 这一课我们来做一些C++开发 ...

  4. 【LeetCode】【Python解读】Container with most water

    这个问题是芭芭拉在采访中遇到的,不幸的是,的复杂性O(n2)该,太失望了,难怪没有通过面试. Given n non-negative integers a1, a2, ..., an, where ...

  5. 【原版的】Redis事件驱动内核

    Redis事件驱动内核 作者:cf (360电商技术组) 概述 Redis实现了自己的事件驱动,与开源事件库libevent.libev一样,都是基于I/O多路复用技术实现的.出于性能和代码精炼双方面 ...

  6. 关于“类不能支持Automation操作”错误的解决方法

    一段程序IE上老是提示“类不支持Automation操作”的错误,IE6.7.8都一样,但是Firefox可以,后来网上找到如下解决方法: 重新注册下以下文件,问题便解决了:msscript.ocxd ...

  7. LINQ之路(2):LINQ to SQL本质

    LINQ之路(2):LINQ to SQL本质 在前面一篇文章中回顾了LINQ基本语法规则,在本文将介绍LINQ to SQL的本质.LINQ to SQL是microsoft针对SQL Server ...

  8. PHP与EXCEL PHPExcel

    1.PHPExcel一个简短的引论 PHPExcel 它是用来操作Office Excel 文档PHP图书馆,它是基于微软的OpenXML标准PHP语言.能够使用它来读.写不同格电子表的类型格,例如 ...

  9. SQL Server 作业监控

    原文:SQL Server 作业监控 在讲解SQLServer Agent Jobs之前,先要讲解msdb. Msdb是SQLServer的系统数据库之一,用于存储SQLServer的配置.元数据等信 ...

  10. 站长VS微商 你选择哪个?

    近期,站长圈里盛行起了一阵面膜风.我刷空间和微信朋友圈的时候,常常看到一些朋友在卖面膜,不光女童鞋在卖,男屌丝站长也在卖. 不光普通人在卖.行业圈的自媒体明星大佬也在卖. 我们暂且称卖面膜的童鞋为微商 ...