迷宫的最短路径

本文介绍了一种使用广度优先搜索(BFS)算法来寻找迷宫中从起点到终点的最短路径的方法。通过构建pair表示状态,并逐步扩展搜索空间,可以有效地解决此类问题。
摘要由CSDN通过智能技术生成

在这里插入图片描述
输入样例:10 10
#S######.#
…#…#
.#.##.##.#
.#…
##.##.####
…#…#
.#######.#
…#…
.####.###.
…#…G#
在这里插入图片描述
思路:bfs按照距开始状态由近及远的顺序搜索,适合求最短路路径、最少操作问题;这个问题中,状态只是位置坐标,可构造pair表达,当状态更复杂时,需要封装成结构体。
代码:

#include<bits/stdc++.h>
using namespace std;
const int maxn=1e2;
const int inf=1e8;//一般将inf设为放大2~4倍不会溢出的大小
typedef pair<int,int>P;//使用pair表示状态时,使用typedef更方便
char maze[maxn][maxn+1];
int N,M,d[maxn][maxn];//d为到各个位置最短距离的数组
int sx,sy,gx,gy;//起点坐标和终点坐标
int dx[4]
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值