UVa 816 Abbott的复仇 (Abbott's Revenge)

这篇博客主要讨论了UVa 816问题,即在一个特殊的9x9迷宫中寻找从起点到终点的最短路径。迷宫的每个交叉点允许的进出方向由NEWS四个字母表示,且路径选择受到进入点方向的影响。解决这个问题的关键在于正确理解题目要求,并能清晰地处理NEWS方向及转弯规则。博客强调理解题意和测试样例的重要性。
摘要由CSDN通过智能技术生成

有一个最多包含9*9个交叉点的迷宫。输入起点,离开起点时的朝向和终点,求一条最短路(多解输出任意一个均可)
这个迷宫的特殊之处在于,进入一个交叉点的方向(用NEWS这四个字母分别表示北东西南,即上右左下)不同,允许出去的方向也不同。例如, 1 2 WLF NR ER * 表示交叉点(1,2)有三个路标,最后一个字符是结束标志,如果进入该点的方向是W,出去只能是L左转和F前进,其他同理。

要点:

  • 理解清楚题干的意思,如果不理解,一定要根据测试样例和输出理解清楚,这非常重要,以防写了很多代码最后无效
  • 没有什么其他需要注意的地方,NEWS这几个方向以及左,右转之后的方向搞清楚即可。
#include<iostream>
#include<string>
#include<cstring>
#include<queue>
#include<list>
using namespace std;

const int maxn = 10;

//dir 0 1 2 3  => N E S W => 向上进来的
enum dir {
    N, E, S, W };

//保存状态,是否被踩过了
bool has[maxn][maxn][4][3];

struct Node {
   
	int x, y;
	dir Dir; //当前节点的x y 值以及朝向
	Node* parent; //当前节点的父亲节点
	Node(int x, int y, dir Dir, Node* parent) :
		x(x), y(y), Dir(Dir), parent(parent) {
   }
};

dir getDir(char ch) {
   
	if (ch == 'N')
		return dir::N;
	if (ch == 'E')
		return dir::E;
	if (ch == 'W')
		return dir::W;
	if (ch == 'S')
		
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值