BFS求最短路 Abbottt's Revenge UVa 816

本题的题意是输入起点,朝向和终点,求一条最短路径(多解时任意输出一个即可)
本题的主要代码是bfs求解,就是以下代码中的slove的主要部分,通过起点按照路径的长度来寻找最短路径,输出最先到终点的一系列点
以下代码中,用两个数组保存四个方向,运用函数walk()表示结点的方向变换,通过d[][][]保存路径的长度,p[][][]保存路径中的结点,has_edge[][][][]标记行得通的路径,同时用队列先进先出,层次遍历所有结点,用vector存储将要输出的结点,防止内存空间不够大
#include<stdio.h>
#include<queue>
#include<string>
#include<string.h>
#include<vector>
#include<iostream>
using namespace std;
const int maxn=;
char name[];
int r0,c0,r1,c1,r2,c2,dir,turn;
char dir0,str[];
int has_edge[maxn][maxn][maxn][maxn]; //表示当前状态,是否可以沿turn的方向行走
int d[maxn][maxn][maxn]; //表示初始状态到(r1,c1,dir)的最短路的长度
string maze_name; const char* dirs="NESW";
const char* turns="FLR";
const int dr[]={-,,,}; //行
const int dc[]={,,,-}; //列
int dir_id(char c){return strchr(dirs,c)-dirs;}
int turn_id(char c){return strchr(turns,c)-turns;} struct Node{
int dir,r,c;
Node(int r=,int c=,int dir=):r(r),c(c),dir(dir){}
}; Node p[maxn][maxn][maxn]; //保存状态 Node walk(const Node& u,int turn){
int dir=u.dir;
if(turn==) dir=(dir+)%; //逆时针
if(turn==) dir=(dir+)%; //顺时针
return Node(u.r+dr[dir],u.c+dc[dir],dir);
} bool inside(int r,int c){
if(r>=&&r<=&&c>=&&c<=) return true;
return false;
} void print_ans(Node u){
vector<Node> nodes;
for(;;){
nodes.push_back(u);
if(d[u.r][u.c][u.dir]==) break;
u=p[u.r][u.c][u.dir];
}
nodes.push_back(Node(r0,c0,dir));
int cnt=;
for(int i=nodes.size()-;i>=;i--){
if(cnt%==) printf(" ");
printf(" (%d,%d)",nodes[i].r,nodes[i].c);
if(++cnt%==) printf("\n");
// printf("(%d,%d)%c",nodes[i].r,nodes[i].c,++cnt%10?' ':'\n');
}
if(nodes.size()%!=) printf("\n");
} void solve(){
memset(d,-,sizeof(d));
queue<Node> q;
d[r1][r2][dir]=;
Node u(r1,c1,dir);
q.push(u);
while(!q.empty()){
u=q.front();
q.pop();
if(u.r==r2&&u.c==c2){
print_ans(u);
return;
}
for(int i=;i<;i++){
Node v=walk(u,i);
if(d[v.r][v.c][i]<&&inside(v.r,v.c)&&has_edge[u.r][u.c][u.dir][i]){
d[v.r][v.c][v.dir]=d[u.r][u.c][u.dir]+;
p[v.r][v.c][v.dir]=u;
q.push(v);
}
}
}
printf("No Solution Possible\n");
} int main(){
freopen("in.txt","r",stdin);
while(scanf("%s",name)){
memset(has_edge,,sizeof(has_edge));
if(strcmp(name,"END")==) break;
scanf("%d%d",&r0,&c0);
scanf("%s",&dir0);
scanf("%d%d",&r2,&c2);
dir=dir_id(dir0);
r1=r0+dr[dir];
c1=c0+dc[dir];
int pr,pc,pdir,pturn;
while(scanf("%d",&pr)&&pr){
scanf("%d",&pc);
while(scanf("%s",str)){
if(str[]=='*'){break;}
pdir=dir_id(str[]);
int len=strlen(str);
for(int i=;i<len;i++){
pturn=turn_id(str[i]);
has_edge[pr][pc][pdir][pturn]=;
}
}
}
cout<<name<<endl;
solve();
}
return ;
}
BFS求最短路 Abbottt's Revenge UVa 816的更多相关文章
- UVA 816 -- Abbott's Revenge(BFS求最短路)
UVA 816 -- Abbott's Revenge(BFS求最短路) 有一个 9 * 9 的交叉点的迷宫. 输入起点, 离开起点时的朝向和终点, 求最短路(多解时任意一个输出即可).进入一个交叉 ...
- 图-用DFS求连通块- UVa 1103和用BFS求最短路-UVa816。
这道题目甚长, 代码也是甚长, 但是思路却不是太难.然而有好多代码实现的细节, 确是十分的巧妙. 对代码阅读能力, 代码理解能力, 代码实现能力, 代码实现技巧, DFS方法都大有裨益, 敬请有兴趣者 ...
- UVa 816 (BFS求最短路)
/*816 - Abbott's Revenge ---代码完全参考刘汝佳算法入门经典 ---strchr() 用来查找某字符在字符串中首次出现的位置,其原型为:char * strchr (cons ...
- POJ 2251 Dungeon Master --- 三维BFS(用BFS求最短路)
POJ 2251 题目大意: 给出一三维空间的地牢,要求求出由字符'S'到字符'E'的最短路径,移动方向可以是上,下,左,右,前,后,六个方向,每移动一次就耗费一分钟,要求输出最快的走出时间.不同L层 ...
- BFS求最短路
假设有一个n行m列的迷宫,每个单位要么是空地(用1表示)要么是障碍物(用0表示).如和找到从起点到终点的最短路径?利用BFS搜索,逐步计算出每个节点到起点的最短距离,以及最短路径每个节点的前一个节点. ...
- 6.4.2 用BFS求最短路
前面的篇幅占了太多,再次新开一章,讲述BFS求最短路的问题 注意此时DFS就没有BFS好用了,因为DFS更适合求全部解,而BFS适合求最优解 这边再次提醒拓扑变换的思想在图形辨认中的重要作用,需要找寻 ...
- 利用BFS求最短路
利用BFS求图的最短路, POJ3984 #define _CRT_SECURE_NO_DEPRECATE #include<iostream> #include<string.h& ...
- hdu 3760(2次bfs求最短路)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3760 思路:首先是建反图,从点n开始做spfa求出n到各点的最短路,然后从1点开始搜最小序列,对于边( ...
- CodeForces - 987D Fair (BFS求最短路)
题意:有N个城市,M条双向道路连接两个城市,整个图保证连通.有K种物品,但每个城市只有一种,现在它们都需要S种物品来举办展览,可以去其他城市获取该城市的物品,花费是两城市之间的最短路径长度.求每个城市 ...
随机推荐
- 基于.net的通用内存缓存模型组件
谈到缓存,我们自然而然就会想到缓存的好处,比如: 降低高并发数据读取的系统压力:静态数据访问.动态数据访问 存储预处理数据,提升系统响应速度和TPS 降低高并发数据写入的系统压力 提升系统可用性,后台 ...
- C#继承中的override(重写)与new(覆盖)用法
刚接触C#编程,我也是被override与new搞得晕头转向.于是花了点时间翻资料,看博客,终于算小有领悟,把学习笔记记录于此. 首先声明一个父类Animal类,与继承Animal的两个子类Dog类与 ...
- mapbox-gl 开发包dev生成
mapbox-gl简介 mapbox-gl采用webgl,提供在线地图实时渲染功能,具有以下特点: 1.多图层显示 2.图层元素显示样式在颜色.字体.大小范围等.是否显示等可实时更改 3.定位抓取选择 ...
- Jxl创建Excel文件和解析Excel文件
import java.io.File; import jxl.Workbook; import jxl.write.Label; import jxl.write.WritableSheet; im ...
- Bean property属性说明
来自为知笔记(Wiz)
- 【游戏开发】Excel表格批量转换成CSV的小工具
一.前言 在工作的过程中,我们有时可能会面临将Excel表格转换成CSV格式文件的需求.这尤其在游戏开发中体现的最为明显,策划的数据文档大多是一些Excel表格,且不说这些表格在游戏中读取的速度,但就 ...
- Altera FIFO IP核时序说明
ALTERA在LPM(library of parameterized mudules)库中提供了参数可配置的单时钟FIFO(SCFIFO)和双时钟FIFO(DCFIFO).FIFO主要应用在需要数据 ...
- Android设置屏幕方向
设置方法:在AndroidManifest.xml中的Activity里加一个属性android:screenOrientation.例如设置该Activity为横向 <activity and ...
- spring aop使用
最近做一个数据库分离的功能,其中用到了spring aop,主要思路就是在service层的方法执行前根据注解(当然也可以根据方法名称,如果方法名称写的比较统一的话)来判断具体使用哪个库.所以想着再回 ...
- java 中 “文件” 和 “流” 的简单分析
java 中 FIle 和 流的简单分析 File类 简单File 常用方法 创建一个File 对象,检验文件是否存在,若不存在就创建,然后对File的类的这部分操作进行演示,如文件的名称.大小等 / ...