迷宫寻路[天梯赛 -- 栈]

题目描述

在这里插入图片描述
在这里插入图片描述

输入样例
8 8	
0 0 1 0 0 0 1 0
0 0 1 0 0 0 1 0
0 0 0 0 1 1 0 0
0 1 1 1 0 0 0 0
0 0 0 1 0 0 0 0
0 1 0 0 0 1 0 0
0 1 1 1 0 1 1 0
1 0 0 0 0 0 0 0
4 4	
0 0 1 0
0 0 0 0
0 0 1 1 
0 1 0 0
-1 -1

输出样例
1,1
2,1
3,1
4,1
5,1
5,2
5,3
6,3
6,4
6,5
7,5
8,5
8,6
8,7
8,8

NO FOUND

思路

bfs

需要对每一条路径上的点进行保存(用temp数组),当找到一条更短路径时,保存其长度,用于后面的遍历中比较;当找到终点时,我们将temp数组中的结果赋值给res数组

AC代码

#include <bits/stdc++.h>
using namespace std;
typedef pair<int, int> PII;
const int N = 1010;
int m, n, min_step;
int g[N][N];
int res[N][2], temp[N][2];
int vis[N][N];
int dir[4][2] = {{-1, 0}, {0, -1}, {0, 1}, {1, 0}};
bool IN(int x, int y)
{
    return x >= 1 && x <= m && y >= 1 && y <= n;
}
void dfs(int x, int y, int step)
{
	if(step > min_step) return;
	
	if(x == m && y == n)
	{
		for(int i = 0; i < N; i ++)
		{
			if(temp[i][0] == -1 && temp[i][1] == -1) break;
			res[i][0] = temp[i][0];
			res[i][1] = temp[i][1];
		}
		min_step = step;
		return;
	}
	
	for(int i = 0; i < 4; i ++)
	{
		int tx = x + dir[i][0];
        int ty = y + dir[i][1];
        if(IN(tx, ty) && g[tx][ty] == 0 && !vis[tx][ty]) 
        {
        	temp[step][0] = tx;
        	temp[step][1] = ty;
        	vis[tx][ty] = true;
        	dfs(tx, ty, step + 1);
        	vis[tx][ty] = false;
		}
	}
	return;
}
int main()
{
	while(1)
	{
		cin >> m >> n;
		if(m == -1) break;
		memset(g, -1, sizeof(g));
		memset(vis, 0, sizeof(vis));
		memset(res, -1, sizeof(res));
		memset(temp, -1, sizeof(temp));
		for(int i = 1; i <= m; i ++)
		{
			for(int j = 1; j <= n; j ++) cin >> g[i][j];
		}
		min_step = 0x3f3f3f3f;
		vis[1][1] = true;
		dfs(1, 1, 0);
		if(min_step != 0x3f3f3f3f) 
		{
			cout << "1,1" << endl;
			for(int i = 0; i < min_step; i ++) cout << res[i][0] << "," << res[i][1] << endl;
            cout << endl;
		}
		else cout << "NO FOUND" << endl;
		//cout << endl;
	}
	return 0;
}

欢迎大家批评指正!!!

相关推荐

  1. 洛谷B3625迷宫

    2024-03-16 16:50:03       29 阅读
  2. 洛谷 B3625 迷宫

    2024-03-16 16:50:03       20 阅读
  3. 2021PTA天梯

    2024-03-16 16:50:03       27 阅读
  4. 2023天梯

    2024-03-16 16:50:03       15 阅读
  5. 2021年CCCC天梯

    2024-03-16 16:50:03       18 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-03-16 16:50:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-16 16:50:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-16 16:50:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-16 16:50:03       18 阅读

热门阅读

  1. C语言基础学习

    2024-03-16 16:50:03       19 阅读
  2. 【CSP考题扩展】暴力枚举(1)

    2024-03-16 16:50:03       21 阅读
  3. Matlab数学建模常用函数

    2024-03-16 16:50:03       21 阅读
  4. Leetcode Algo Day6 | Hashtable Part1

    2024-03-16 16:50:03       21 阅读
  5. 使用vue3 开发H5 ,需要注意的部分点

    2024-03-16 16:50:03       19 阅读
  6. AcWing 4261. 孤独的照片(每日一题)

    2024-03-16 16:50:03       26 阅读
  7. 机器学习模型—Gradient Boosting

    2024-03-16 16:50:03       19 阅读
  8. 堆的建立与排序

    2024-03-16 16:50:03       17 阅读