ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

求迷宫最短通道

2022-06-22 01:32:54  阅读:170  来源: 互联网

标签:int 迷宫 最短 步长 数组 maze 通道


递归求解迷宫最短通道的总步长。输入一个迷宫,求从入口通向出口的可行路径中最短的路径长度。为简化问题,迷宫用二维数组
int maze[10][10]来存储障碍物的分布,假设迷宫的横向和纵向尺寸的大小是一样的,并由程序运行读入, 若读入迷宫大小的值是n(3<n<=10),则该迷宫横向或纵向尺寸都是n,规定迷宫最外面的一圈是障碍物,迷宫的入口是maze[1][1],出口是maze[n-2][n-2], 若maze[i][j] = 1代表该位置是障碍物,若maze[i][j] = 0代表该位置是可以行走的空位(0<=i<=n-1, 0<=j<=n-1)。求从入口maze[1][1]到出口maze[n-2][n-2]可以走通的路径上经历的最短的总步长。要求迷宫中只允许在水平或上下四个方向的空位上行走,走过的位置不能重复走。

输入格式:

输入迷宫大小的整数n, 以及n行和n列的二维数组(数组元素1代表障碍物,0代表空位)

输出格式:

若有可行的通道则输出一个整数,代表求出的通道的最短步长;若没有通道则输出"No solution"

#include<bits/stdc++.h>
using namespace std;
int l;
int ans=1000;
int step=0; 
int maze[100][100];
int movex[5]={0,1,-1,0,0};
int movey[5]={0,0,0,1,-1};
void dfs(int x, int y)
{
	if(x>=l||y>=l||x<0||y<0||maze[x][y]==1)
	{
		return ;
	}
	if(x==l-2&&y==l-2)
	{
		if(ans>step)
		{
			ans=step;
		}
		return;
	}
	for(int i=1;i<=4;i++)
	{
		step++;//假设这个点正确,步数+1
		maze[x][y]=1;//走过
		dfs(x+movex[i],y+movey[i]);//继续走,直到无法通过或到出口
		maze[x][y]=0;//无法通过退回;到出口退回寻找其它路;
		step--;//相当于还没走,步数-1;
	}
	
}
int main()
{
	cin>>l;
	int i,j;
	for(i=0;i<l;i++)
	{
		for(j=0;j<l;j++)
		{
			cin>>maze[i][j];
		}
	}
	dfs(1,1);
	cout<<ans;
	return 0;
}

 

标签:int,迷宫,最短,步长,数组,maze,通道
来源: https://www.cnblogs.com/iceforever7/p/16399005.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有