前言
在上一篇文章中,我们了解了宽搜及其相关概念,那么这篇文章就为大家带来几个经常出现的宽搜题目(题目类型自己总结,请见谅)
最小步数
前话
作为宽搜最大的优点,最小步数一类题也当之不愧的成为宽搜具有代表性的一类题,有些最小步数题深搜也能做,但是数据大了就会超时爆空间,宽搜的好处也就凸显出来了
例题
例题:走迷宫
题目描述:一个人在一个迷宫,每走一步只能向上下左右四个方向移动,请你帮小可找出从起点到终点的最短路程。
对于每组输入,输出从起点到终点的最短路程,如果不存在从起点到终点的路,则输出-1。
输入包含多组测试数据。输入的第一行是一个整数T,表示有T组测试数据。
每组输入的第一行是两个整数N和M(1<=N,M<=100)。
接下来N行,每行输入M个字符,每个字符表示迷宫中的一个小方格。
字符的含义如下:
‘S’:起点
‘E’:终点
‘-’:空地,可以通过
‘#’:障碍,无法通过
输入数据保证有且仅有一个起点和终点。
样例:输入 1
s-###
-----
##—
E#—
—##
输出:9
题目理解
这个题就很直接的让求从入口到出口的最短路程,那么我们在一开始的时候将起点的终点的坐标保存下来,用结构体来构建每个点的x坐标和y坐标用四方向方向数组来模拟向四个方向走,用标记数组保证不走重复的路,同时步数数组不断记录到每一个点的最短路程长就好了,最后判断下是否有答案来是否输出-1。
同时对于多组输入,就要将step(步数)数组在每一次的开始进行清空,防止干扰后续程序运行
主要宽搜函数
struct node{
int x,y;
};
void bfs(int x,int y){
queue<node> q;
node tmp; //建立临时数,便于将起点放入队列
tmp.x=x,tmp.y=y;
q.push(tmp);
a[x][y]='#'; //防止走重复点
while(!q.empty()){
node t=q.front();
q.pop();
if(t.x==ex&&t.y==ey){
//判断是否到达终点
cout<<step[ex][ey]<<endl; //输出最小步数
flag=