宽度优先搜索(二)

前言

在上一篇文章中,我们了解了宽搜及其相关概念,那么这篇文章就为大家带来几个经常出现的宽搜题目(题目类型自己总结,请见谅)

最小步数

前话

作为宽搜最大的优点,最小步数一类题也当之不愧的成为宽搜具有代表性的一类题,有些最小步数题深搜也能做,但是数据大了就会超时爆空间,宽搜的好处也就凸显出来了

例题

例题:走迷宫
题目描述:一个人在一个迷宫,每走一步只能向上下左右四个方向移动,请你帮小可找出从起点到终点的最短路程。
对于每组输入,输出从起点到终点的最短路程,如果不存在从起点到终点的路,则输出-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=
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值