走迷宫---dfs在矩阵图里的应用模板

题目描述如下:

dfs算法解决迷宫问题的一个标准模板 ,通过递归与回溯暴力遍历所有能走的点,并比较找出所有可行方案的最优解

解决这道问题的核心思想和组合数如出一辙,可以说是组合数的升级版

结合注释看dfs更清晰易懂,这里不再空对空的讲述了

(本题要用bfs写,dfs会超时,但dfs找路径的核心思想是很值得学习的,而且dfs比bfs的代码更简洁更好理解,打oi赛制是可以得到部分分的)

能过样例的代码如下:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
const int N=110;
int a[N][N];
bool check[N][N];//记录该位置是否走过(保证一个方案内不回头)
int mi=1e8;//最小步数,初始化为无穷大 
void dfs(int stx,int sty,int step){//stx->start x,sty->start y
	int next[4][2]={{1,0},{0,-1},{-1,0},{0,1}};//下一步分别走右,下,左,上的方案
	int nx,ny;//将要走到下一个位置的的坐标
	if(stx==n&&sty==m) {//判断是否走到目标位置 
		if(step<mi){//更新最小步数 
			mi=step;
		}
		return;
	}
	for(int k=0;k<4;k++){
		//计算下一个点坐标 
		nx=stx+next[k][0];
		ny=sty+next[k][1];
		//判断是否越界,若越界直接continue重新走下一个方向,不往下递归(走出下一步) 
		if (nx<1||nx>n||ny<1||ny>m){
			continue;
		} 
		//判断下一个点走过没有,判断下一个点是否为障碍物,若不是,则递归(走出下一步) 
		if(check[nx][ny]==false&&a[nx][ny]==0){
			check[nx][ny]=true;//标记为走过(和组合数的模板一样) 
			dfs(nx,ny,step+1);
			check[nx][ny]=false;//回溯的过程,这一步不走了,把卡片拿回来 
		}
	}
} 
int main(){
	int n,m;
	cin>>n>>m;
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			cin>>a[i][j];
		}
	}
	check[1][1]=true;//标记起点坐标已走过 
	dfs(1,1,0);//传入起点坐标和此时的步数:0 
	cout<<mi;
	return 0;
}
相关推荐
先做个垃圾出来………11 分钟前
偏移量解释
数据结构·算法
FanXing_zl16 分钟前
基于整数MCU的FOC控制定标策略深度解析
单片机·嵌入式硬件·mcu·算法·定点运算·q15
立志成为大牛的小牛30 分钟前
数据结构——三十三、Dijkstra算法(王道408)
数据结构·笔记·学习·考研·算法·图论
地平线开发者1 小时前
mul 与 reduce_sum 的优化实例
算法·自动驾驶
坚持编程的菜鸟2 小时前
LeetCode每日一题——Pow(x, n)
c语言·算法·leetcode
csdn_aspnet2 小时前
分享MATLAB在数据分析与科学计算中的高效算法案例
算法·matlab·数据分析
白云千载尽2 小时前
moveit使用和机器人模型与状态--正向运动学和逆向运动学分析(四)
算法·机器人·逆运动学·moveit·正向运动学
我想吃余2 小时前
【0基础学算法】前缀和刷题日志(三):连续数组、矩阵区域和
算法·矩阵·哈希算法
2501_938773993 小时前
文档搜索引擎搜索模块迭代:从基础检索到智能语义匹配升级
人工智能·算法·搜索引擎
CS创新实验室3 小时前
典型算法题解:长度最小的子数组
数据结构·c++·算法·考研408