acwing走迷宫

news2024/11/30 10:37:53
迷宫题目

给定一个 n×m 的二维整数数组,用来表示一个迷宫,数组中只包含 0 或 1,其中 0 表示可以走的路,1 表示不可通过的墙壁。最初,有

一个人位于左上角 (1,1)处,已知该人每次可以向上、下、左、右任意一个方向移动一个位置。请问,该人从左上角移动至右下角 (n,m) 处,

至少需要移动多少次。数据保证 (1,1) 处和 (n,m) 处的数字为 0,且一定至少存在一条通路。

输入格式

第一行包含两个整数 n 和 m。

接下来 n 行,每行包含 m 个整数(0 或 1),表示完整的二维数组迷宫。

输出格式

输出一个整数,表示从左上角移动至右下角的最少移动次数。

数据范围

1 ≤ n , m ≤ 100 。 1≤n,m≤100。1≤n,m≤100。

输入样例:

5 5
0 1 0 0 0
0 1 0 1 0
0 0 0 0 0
0 1 1 1 0
0 0 0 1 0

输出样例:

8

题解:

这道题算是bfs的一道典型的例题了,下面来介绍一下写这种题的步骤:

在这里插入图片描述

1、首先可以在实例的迷宫先标上序号

在这里插入图片描述

在这里插入图片描述

2、依次去寻找距离原点长度为1、2、3……的坐标,这里举一些特殊的情况:距离为3的点 ,最后可以得到如上图所示

代码
#include <iostream>

using namespace std;
typedef pair<int, int> PII;


const int N = 110;

int n, m;
int Map[N][N];//记录整个迷宫
int s[N][N];//表示每个点到原点的距离



PII q[N * N];//定义一个队列

//对应着上下左右四个方向
int dx[4] = {-1,+1,0,0};
int dy[4] = {0,0,-1,+1};
int dfs()
{
	//初始化一个队列
	int hh = 0 , tt = 0;
	q[0] = {0,0};
	//将s数组初始化成0,每个点到原点的距离都为0
	memset(s, -1, sizeof s);
	//{0,0}点就在原点  距离为0
	s[0][0] = 0;

	//当队列不为空
	while (hh <= tt)
	{
		//取出队列的头元素
		auto t = q[hh ++ ];
		//去初始化s数组
		for (int i = 0 ; i < 4; i++)//每一个点都按照可以上下左右四个方向来判断
		{
			int x = t.first + dx[i], y = t.second + dy[i];
			if (x < n && x >= 0 && y < m && y >= 0 && Map[x][y] == 0 && s[x][y] == -1)
			{
				s[x][y] = s[t.first][t.second] + 1;//新判断的这个点是上一个点到原点的距离 加一

				q[++tt] = { x,y };//将判断好的值加进队列中去
			}
		}
	}

	return s[n-1][m-1];
}

int main()
{
	cin >> n >> m;
	for (int i = 0; i < n; i++)
		for (int j = 0; j < m; j++)
			cin >> Map[i][j];//输入整个迷宫

	cout << dfs() << endl;

	return 0;
}
输出路径版本的代码
#include <iostream>

using namespace std;
typedef pair<int, int> PII;


const int N = 110;

int n, m;
int Map[N][N];//记录整个迷宫
int s[N][N];//表示每个点到原点的距离


PII q[N * N],Prev[N][N];//定义一个队列

//对应着上下左右四个方向
int dx[4] = {-1,+1,0,0};
int dy[4] = {0,0,-1,+1};
int dfs()
{
	//初始化一个队列
	int hh = 0 , tt = 0;
	q[0] = {0,0};
	//将s数组初始化成0,每个点到原点的距离都为0
	memset(s, -1, sizeof s);
	//{0,0}点就在原点  距离为0
	s[0][0] = 0;

	//当队列不为空
	while (hh <= tt)
	{
		//取出队列的头元素
		auto t = q[hh ++ ];
		//去初始化s数组
		for (int i = 0 ; i < 4; i++)//每一个点都按照可以上下左右四个方向来判断
		{
			int x = t.first + dx[i], y = t.second + dy[i];
			if (x < n && x >= 0 && y < m && y >= 0 && Map[x][y] == 0 && s[x][y] == -1)
			{
				s[x][y] = s[t.first][t.second] + 1;//新判断的这个点是上一个点到原点的距离 加一
				Prev[x][y] = t ; //每次判断好的点 都存储到Prev数组中
				q[++tt] = { x,y };//将判断好的值加进队列中去
			}
		}
	}

	int x = n - 1, y = m - 1;
	while (x || y)
	{
		//先输出最后一个点的坐标
		cout << x << ' ' << y << endl;
		//找到最后一个点的前一个点的坐标
		auto t = Prev[x][y];
		x = t.first, y = t.second;
	}

	return s[n-1][m-1];
}

int main()
{
	cin >> n >> m;
	for (int i = 0; i < n; i++)
		for (int j = 0; j < m; j++)
			cin >> Map[i][j];//输入整个迷宫

	cout << dfs() << endl;

	return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2059667.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

20:【stm32】定时器一:时基单元

时基单元 1、什么是定时器2、时基单元的基本结构2.1&#xff1a;脉冲的来源2.2&#xff1a;预分频器PSC2.3&#xff1a;计数器CNT2.4&#xff1a;update事件与预加载 3、标准库编程3.1&#xff1a;通过定时器中断来设置延迟函数 1、什么是定时器 定时器是一种专门负责定时功能…

5个自动化面试题,助你过关斩将!

一、python深拷贝与浅拷贝的区别 Python中的深拷贝&#xff08;deep copy&#xff09;和浅拷贝&#xff08;shallow copy&#xff09;是两种不同的对象复制方式&#xff0c;它们之间的主要区别在于复制的内容和范围。 浅拷贝&#xff08;Shallow Copy&#xff09; 浅拷贝会创…

最新官方破解版FL Studio24.1.1安装包下载

大家好&#xff01;&#x1f44b;今天我要和大家分享一款让我彻底着迷的音乐制作神器——FL Studio 24.1.1中文版本。作为一个热爱音乐的创作者&#xff0c;我一直在寻找能让我更高效、更有创意地完成作品的软件。直到我遇到了它&#xff0c;我的世界彻底改变了&#xff01; 【…

操作系统(Ubuntu安装配置)

1.1.什么是操作系统 操作系统&#xff08;Operating System&#xff0c;简称OS&#xff09;是一种系统软件&#xff0c;它是计算机硬件和应用软件之间的桥梁。它管理计算机的硬件和软件资源&#xff0c;为应用程序提供接口和服务&#xff0c;并协调应用程序的运行。操作系统是…

超声波清洗机是智商税吗?专业博主分享四大必买超声波清洗机款式

有些人觉得超声波清洗机不过是个“智商税”&#xff0c;花几百块买个小盒子不值当&#xff0c;毕竟自己用手也能清洗。但这种看法过于片面。事实上&#xff0c;超声波清洗已经有几十年的历史&#xff0c;随着科技的发展&#xff0c;现代超声波清洗机不仅能够批量、自动清洁&…

C#学习之路day2

一、变量 用来在存储计算机当中存储数据 1、常见的数据类型&#xff0c; 2、声明变量的方式 *声明&#xff1a;变量类型 变量名 &#xff1b; *赋值&#xff1a;变量名 值 &#xff1b; 先声明 &#xff0c;再赋值 &#xff0c;再使用 int num ; //声明num 10; //赋值i…

无人系统特刊合集(一)丨MDPI特刊推荐

特刊征稿 01 特刊名称&#xff1a; Civil and Public Domain Applications of Unmanned Aviation 参与期刊&#xff1a; 截止时间&#xff1a; 摘要提交截止日期 2024年10月31日 投稿截止日期 2024年12月31日 目标及范围&#xff1a; 在过去十年中&#xff0c;无人系统经历…

号称企业通讯利器的智能接打电话机器人,好用吗?

企业为了提升效率、优化客户体验&#xff0c;不断探索新的技术工具。智能接打电话机器人作为其中的佼佼者&#xff0c;正逐渐受到市场的广泛关注。那么&#xff0c;智能接打电话机器人究竟好用吗&#xff1f;它能为企业带来哪些实质性的改变呢&#xff1f; 一、智能接打电话机器…

【HTML】弹性盒子 (display: flex) 布局

Flex弹性布局 容器属性flex-direction&#xff08;主轴的方向&#xff09;flex-wrap&#xff08;主轴的项目换行&#xff09;justify-content&#xff08;项目在主轴上的对齐方式&#xff09;align-items&#xff08;项目在交叉轴上的对齐方式&#xff09;align-content&#x…

开学季必备神器!南卡Pro5骨传导耳机,运动学习两不误!

随着科技的不断进步&#xff0c;耳机已经从单纯的听觉工具&#xff0c;演变成了我们日常生活中不可或缺的伴侣。特别是在充满活力的开学季&#xff0c;一款好的耳机不仅能提升学习效率&#xff0c;还能在运动时提供额外的动力。而骨传导技术的出现&#xff0c;更是为耳机领域带…

Flutter入门——从简单的计数器demo入手

Flutter入门——从简单的计数器demo入手 前言 flutter是现如今很热门的跨平台开发框架&#xff0c;只需要一套代码就能在六个平台上运行&#xff0c;现在在移动端的应用比较成熟&#xff0c;本片文章会是Flutter的简单入门&#xff0c;从一个简单的demo入手分析 笔者是Android…

OpenCvSharp.Internal.NativeMethods“的类型初始值设定项引发异常

错误截图&#xff1a; WPF项目 A界面按钮方法调用成员实例B里面这个初始化Mat对象方法 后台ViewModel代码类似&#xff1a; AViewModel{ B b; public void BtnClick(){ b.test(); } } 报错&#xff1a; 看一眼根据经验确认是DLL的问题&#xff0c;于是乎把nuget包配置和…

毛中特25版肖1000题选择题知识点(乱序)

马原&#xff1a;马原25版肖1000题选择题知识点&#xff08;乱序&#xff09;-CSDN博客 毛泽东明确提出的&#xff0c;是把马克思列宁主义基本原理同中国具体实际进行“第二次结合&#xff0c;找出在中国怎样建设社会主义的道路”的任务&#xff0c;不是“第二个结合”(马克思…

USB3.2 摘录(五)

系列文章目录 USB3.2 摘录&#xff08;一&#xff09; USB3.2 摘录&#xff08;二&#xff09; USB3.2 摘录&#xff08;三&#xff09; USB3.2 摘录&#xff08;四&#xff09; USB3.2 摘录&#xff08;五&#xff09; 文章目录 系列文章目录8 协议层&#xff08;Protocol Lay…

爽了!免费的SSL,还能自动续期,支持CDN/OSS!

作者&#xff1a;小傅哥 博客&#xff1a;https://bugstack.cn 沉淀、分享、成长&#xff0c;让自己和他人都能有所收获&#xff01;&#x1f604; 大家好&#xff0c;我是技术UP主小傅哥。 从今年开始&#xff0c;越来越多的云服务厂商开始限制了 ssl 1年期的申请&#xff0c…

Linux驱动学习之点灯(四,linux2.6)

上篇最后的第二种点灯方法年代比较久远&#xff0c;register_chrdev&#xff08;&#xff09;这个函数一下申请了255个设备号&#xff0c;不建议使用 如下图 下图的函数在linux2.6里是上图函数的升级版&#xff0c;不过他是静态分配&#xff0c;后续还得添加到cdev里 从上图函…

计算机的演进之路:历史与组成结构全解析

一、计算机发展历史 &#xff08;一&#xff09;早期计算工具 在计算机诞生之前&#xff0c;人类为了进行计算发明了许多工具。例如&#xff0c;中国古代的算筹和算盘&#xff0c;它们在一定程度上满足了人们进行简单数学运算的需求。而在西方&#xff0c;古希腊的安提凯希拉…

收银系统源码-千呼新零售2.0【线下收银】

千呼新零售2.0系统由零售行业连锁店一体化收银系统和多商户入驻平台商城两个板块组成&#xff0c;打造门店平台的本地生活即时零售模式。 其中连锁店收银系统包括线下收银私域商城连锁店管理ERP管理商品管理供应商管理会员营销等功能为一体&#xff0c;线上线下数据全部打通。…

相机模型与成像过程:深入解析相机内参、外参及标定方法

相机模型与成像过程&#xff1a;深入解析相机内参、外参及标定方法 引言 相机作为图像采集的重要设备&#xff0c;在图像处理、计算机视觉及机器视觉等领域扮演着核心角色。了解相机的成像原理、模型参数及标定方法&#xff0c;对于提升图像质量和后续处理效果至关重要。本文…

嵌入式学习Day36---Linux软件编程---网络编程

目录 一、TCP并发模型 1.1.阻塞IO 1.2.非阻塞IO 1.步骤 2.函数接口 3.实例 1.3.异步IO 1.步骤 2.函数接口 3.实例 1.4.多路复用IO 1.select 函数接口&#xff1a; 实例 2.poll 3.epoll 二、总结 一、TCP并发模型 1.1.阻塞IO CPU占用率低,等待资源时将任务挂…