迷宫问题~写题笔记

2024-04-29 09:38
文章标签 问题 笔记 迷宫 写题

本文主要是介绍迷宫问题~写题笔记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

定义一个二维数组:

int maze[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,};


它表示一个迷宫,其中的1表示墙壁,0表示可以走的路,只能横着走或竖着走,不能斜着走,要求编程序找出从左上角到右下角的最短路线。

Input

一个5 × 5的二维数组,表示一个迷宫。数据保证有唯一解。

Output

左上角到右下角的最短路径,格式如样例所示。

Sample Input

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

Sample Output

(0, 0)
(1, 0)
(2, 0)
(2, 1)
(2, 2)
(2, 3)
(2, 4)
(3, 4)
(4, 4)
#include<iostream>
#include<algorithm>
#include<cstring>
#include<stack>
#include<cstdio>
using namespace std;
int Map[10][10];
int Min = 99999;
int vis[10][10];
int dir[4][2] = {1,0,0,1,-1,0,0,-1};
struct node
{int x, y;}a,tmp[100];
stack<node> s;
int m = 0;
void dfs(int x, int y, int step)
{//cout << "x=" << x << " " << "y=" << y << endl; if(x == 4 && y == 4){	if(step < Min) {m = 0;Min =  step ;while(!s.empty()){tmp[m++] = s.top();//	cout << s.top().x << " " << s.top().y << endl;s.pop();}for(int i = m-1; i >= 0; i--){s.push(tmp[i]);}			return ;}}for(int i = 0; i < 4; i++){int nx = x + dir[i][0];int ny = y + dir[i][1];if(!vis[nx][ny] && Map[nx][ny] == 0  && nx >= 0 && nx <= 4 && ny >= 0 && ny <= 4){ a.x = nx, a.y = ny;s.push(a);vis[nx][ny] = 1;dfs(nx, ny, step+1);s.pop();vis[nx][ny] = 0;}}}
int main()
{for(int i = 0; i <= 4; i++){for(int j = 0; j < 5; j++){cin >> Map[i][j];	}	}vis[0][0] = 1;dfs(0,0,0) ;
//	cout << Min << endl;printf("(0, 0)\n");for(int i =  Min - 1; i >= 0; i--) cout << "(" << tmp[i].x << ", " << tmp[i].y << ")"<< endl;return 0;}

以下bfs只求出步数

#include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdio>
#include<queue>
using namespace std;
struct node
{int x, y;int step;node(){}node(int _x, int _y, int _step) : x(_x),y(_y),step(_step) {} //构造函数 
};
int Map[10][10];
//int Min = 9999;
int vis[10][10];
int dir[4][2] = {0,1,1,0,0,-1,-1,0};
int bfs()
{queue<node> q;q.push(node(0,0, 0));memset(vis, 0, sizeof(vis));vis[0][0] = 1;int flag = 0;while(!q.empty()){struct node now;now = q.front();if(now.x == 4 && now.y == 4) {return now.step; }q.pop();vis[now.x][now.y] = 0;for(int i = 0; i < 4; i++){struct node next;next.x = now.x + dir[i][0];next.y = now.y + dir[i][1];next.step = now.step + 1;if(!vis[next.x][next.y] && next.x >= 0 && next.x < 5 && next.y >= 0 && next.y < 5){vis[next.x][next.y] = 1;q.push(next); } }}}
int main()
{for(int i = 0; i < 5; i++){for(int j = 0; j < 5; j++){cin >> Map[i][j];}}cout << bfs() << endl;return 0; 
}

 

这篇关于迷宫问题~写题笔记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/945736

相关文章

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

解决Nginx启动报错Job for nginx.service failed because the control process exited with error code问题

《解决Nginx启动报错Jobfornginx.servicefailedbecausethecontrolprocessexitedwitherrorcode问题》Nginx启... 目录一、报错如下二、解决原因三、解决方式总结一、报错如下Job for nginx.service failed bec

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

MySQ中出现幻读问题的解决过程

《MySQ中出现幻读问题的解决过程》文章解析MySQLInnoDB通过MVCC与间隙锁机制在可重复读隔离级别下解决幻读,确保事务一致性,同时指出性能影响及乐观锁等替代方案,帮助开发者优化数据库应用... 目录一、幻读的准确定义与核心特征幻读 vs 不可重复读二、mysql隔离级别深度解析各隔离级别的实现差异

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基

Python多线程应用中的卡死问题优化方案指南

《Python多线程应用中的卡死问题优化方案指南》在利用Python语言开发某查询软件时,遇到了点击搜索按钮后软件卡死的问题,本文将简单分析一下出现的原因以及对应的优化方案,希望对大家有所帮助... 目录问题描述优化方案1. 网络请求优化2. 多线程架构优化3. 全局异常处理4. 配置管理优化优化效果1.