华为机考:HJ43 迷宫问题

华为机考:HJ43 迷宫问题

描述

DFS

从迷宫入口开始进行dfs搜索,每次进入一个点,将其加入临时路径数组中,把该位改成0表示不能进入,然后依次搜索该位下、右、上、左四个方向的点,如果搜索的这个点可以进入则路径进入,如果四个方向都没有可以走的路表示此路不通,回溯------删去路径最后一个,重置该位为0. 找到横纵坐标都等于矩阵最后一位则表示找到路径,复制现有路径然后返回。

cpp 复制代码
#include<iostream>
#include<vector>
using namespace std;
vector<pair<int,int>> res;
void dfs(vector<vector<int>>& matrix, int n, int m, int i, int j, vector<pair<int,int>>& paths) {
	//在每次递归调用时,程序首先将当前位置 (i, j) 记录到 paths 中,并将该位置标记为已经访问过。然后检查是否到达终点 (n-1, m-1),如果到达终点则将路径保存到全局变量 res 中,并返回。
	paths.push_back(make_pair(i, j));
	matrix[i][j] = 1;  
	if (i == n - 1 && j == m - 1) {
		res = paths;
		return;
	}
	//向下、向右、向上、向左。对于每个方向,判断是否在迷宫范围内且可以通行(值为0),如果满足条件则递归调用 dfs 继续搜索。
	if (i + 1 < n && matrix[i + 1][j] == 0) { //下
		dfs(matrix, n, m, i + 1, j, paths);
	}
	if (j + 1 < m && matrix[i][j + 1] == 0) { //右
		dfs(matrix, n, m, i, j + 1, paths);
	}
	if (i - 1 >= 0 && matrix[i - 1][j] == 0) {  //上
		dfs(matrix, n, m, i - 1, j, paths);
	}
	if (j - 1 >= 0 && matrix[i][j - 1] == 0) {   //左
		dfs(matrix, n, m, i, j - 1, paths);
	}
	paths.pop_back();
	matrix[i][j] = 0;
}

int main()
{
	int n, m;
	while (cin >> n >> m) {
		vector<vector<int>> matrix(n, vector<int>(m,0));
		for (int i = 0; i < n; ++i) {
			for (int j = 0; j < m; ++j) {
				cin >> matrix[i][j];
			}
		}
		vector <pair<int, int >> paths;
		dfs(matrix, n, m, 0, 0, paths);
		for (int i = 0; i < res.size(); ++i) {
			cout << "(" << res[i].first << "," << res[i].second << ")" << endl;
		}
	}
	return 0;
}

华为机考:HJ43 迷宫问题

相关推荐
small_wh1te_coder2 分钟前
硬件嵌入式学习路线大总结(一):C语言与linux。内功心法——从入门到精通,彻底打通你的任督二脉!
linux·c语言·汇编·嵌入式硬件·算法·c
挺菜的35 分钟前
【算法刷题记录(简单题)002】字符串字符匹配(java代码实现)
java·开发语言·算法
凌肖战4 小时前
力扣网编程55题:跳跃游戏之逆向思维
算法·leetcode
88号技师5 小时前
2025年6月一区-田忌赛马优化算法Tianji’s horse racing optimization-附Matlab免费代码
开发语言·算法·matlab·优化算法
ゞ 正在缓冲99%…5 小时前
leetcode918.环形子数组的最大和
数据结构·算法·leetcode·动态规划
Kaltistss6 小时前
98.验证二叉搜索树
算法·leetcode·职场和发展
知己如祭6 小时前
图论基础(DFS、BFS、拓扑排序)
算法
mit6.8246 小时前
[Cyclone] 哈希算法 | SIMD优化哈希计算 | 大数运算 (Int类)
算法·哈希算法
c++bug6 小时前
动态规划VS记忆化搜索(2)
算法·动态规划
哪 吒6 小时前
2025B卷 - 华为OD机试七日集训第5期 - 按算法分类,由易到难,循序渐进,玩转OD(Python/JS/C/C++)
python·算法·华为od·华为od机试·2025b卷