HJ160 迷宫

  • 题目
  • 题解(8)
  • 讨论(9)
  • 排行

中等 通过率:19.57% 时间限制:2秒 空间限制:256M

知识点广度优先搜索(BFS)

校招时部分企业笔试将禁止编程题跳出页面,为提前适应,练习时请使用在线自测,而非本地IDE。

描述

给定一个 n×mn×m 的迷宫,迷宫由 "#" 与"." 两种字符组成。其中 "#" 代表障碍物,"." 表示空地。迷宫中还有一个起点 "S" 和一个终点 "E" ,它们都可以视为空地。

由于近期迷宫发生了塌方,导致起点和终点之间可能并不连通。幸运的是,你拥有一种超能力------在迷宫中移动时(移动方向为上、下、左、右四个方向之一),可以在当前位置朝任一方向(上、下、左、右四个方向之一)释放激光。激光能够清除该方向上所有的障碍物,并且这种超能力至多只能使用一次。

现在,你需要判断是否能利用这种超能力成功从起点到达终点。

输入描述:

第一行给定两个整数 n,m(2≦n,m≦1000)n,m(2≦n,m≦1000) ,分别表示迷宫的行数和列数。

下面 nn 行,每行 mm 个字符,描述迷宫的具体布局。字符只包含 "#"、"."、"S" 和 "E",并且起点与终点有且仅有一个。

输出描述:

能够到达终点输出 YESYES ;否则输出 NONO。

示例1

输入:

复制代码
4 5
.####
S####
.####
.E###

复制输出:

复制代码
YES

复制

示例2

输入:

复制代码
4 5
..###
S####
#####
##.E#

复制输出:

复制代码
YES

复制说明:

复制代码

显然可以从起点出发,到达(1,2)(1,2)处并向下方使用超能力,此时可以从起点到达终点。

示例3

输入:

复制代码
4 5
..###
S####
#####
###E#

复制输出:

复制代码
NO
cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

int n, m;
vector<pair<int, int>> min_max_row(2,{0x3f3f3f3f,0}); //min,max
vector<pair<int, int>> min_max_column(2,{ 0x3f3f3f3f,0 }); //min,max
pair<int, int> start;
pair<int, int> the_end;
int dx[] = { 0,0,1,-1 };
int dy[] = { 1,-1,0,0 };

bool visited[1001][1001];

bool check(vector<vector<char>>& graph, int x, int y) {
	if (x < n && y < m && x >= 0 && y >= 0 &&!visited[x][y] && graph[x][y] == '.') {
		return true;
	}
	return false;
}

void dfs(vector<vector<char>> &graph , int x,int y,int index) {
	visited[x][y] = true;
	min_max_column[index].first = min(min_max_column[index].first, x);
	min_max_column[index].second = max(min_max_column[index].second, x);
	min_max_row[index].first = min(min_max_row[index].first, y);
	min_max_row[index].second = max(min_max_row[index].second, y);
	for (int k = 0; k < 4; k++) {
		if (check(graph, x + dx[k], y + dy[k])) {
			dfs(graph, x + dx[k], y + dy[k],index);
		}
	}
}

int main() {

	cin >> n >> m;
	vector<vector<char>> graph(n, vector<char>(m));
	for (int k = 0; k < n; k++) {
		for (int j = 0; j < m; j++) {
			cin >> graph[k][j];
			if (graph[k][j] == 'S') {
				start = { k,j };
				graph[k][j] = '.';
			}
			if (graph[k][j] == 'E') {
				the_end = { k,j };
				graph[k][j] = '.';
			}
		}
	}
	dfs(graph, start.first, start.second, 0);
	memset(visited, false, sizeof(visited));
	dfs(graph, the_end.first, the_end.second, 1);
	if (min_max_row[0].first <= min_max_row[1].second + 1 && min_max_row[0].second >= min_max_row[1].first - 1) {
		cout << "YES";
		return 0;
	}
	if (min_max_column[0].first <= min_max_column[1].second + 1 && min_max_column[0].second >= min_max_column[1].first - 1) {
		cout << "YES";
		return 0;
	}
	cout << "NO";
	return 0;

}
相关推荐
Kethy__2 小时前
计算机中级-数据库系统工程师-数据结构-树与二叉树(1)
数据结构·算法··数据库系统工程师·计算机中级
炘爚2 小时前
C++(移动构造、移动赋值、完美转发)
前端·c++
环黄金线HHJX.2 小时前
BaClaw龙虾打字
开发语言·人工智能·算法·编辑器
王老师青少年编程2 小时前
csp信奥赛c++之字符数组与字符串的区别
c++·字符串·字符数组·csp·信奥赛
AI科技星2 小时前
光速螺旋量子几何统一场论:基于四维类时螺旋的物理现象统一推导
开发语言·线性代数·算法·数学建模·平面
We་ct2 小时前
LeetCode 191. 位1的个数:两种解法详解
前端·算法·leetcode·typescript
vx_biyesheji00012 小时前
计算机毕业设计:Python汽车市场智能决策系统 Flask框架 可视化 机器学习 AI 大模型 大数据(建议收藏)✅
大数据·人工智能·python·算法·django·汽车·课程设计
2501_920627612 小时前
Flutter 框架跨平台鸿蒙开发 - 编程代码库应用
学习·算法·flutter·华为·harmonyos
每天回答3个问题2 小时前
掌握常见的容器的用法
算法·深度优先