mm的雷达2 走迷宫3

yang_zhiyu 2023-11-25 10:49:09 2023-11-25 10:49:47

#include<bits/stdc++.h>
using namespace std;

const int N=1000+10;
const int dx[]={0,0,-1,1};
const int dy[]={-1,1,0,0};
struct Node
{
	int x,y;
};

char maze[N][N];
int dep[N][N];
queue<Node> que;

int main()
{
	int n,m;
	cin>>n>>m;
	
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=m;j++)
		{
			cin>>maze[i][j];
		} 
	}
	memset(dep,-1,sizeof(dep));
	dep[1][1]=0;
	que.push({1,1});
	while(!que.empty())
	{
		int x=que.front().x,y=que.front().y;
		que.pop();
		for(int i=0;i<4;i++)
		{	
			int nx=x+dx[i],ny=y+dy[i];
			while(nx>=1&&nx<=n&&ny>=1&&ny<=m&&maze[nx][ny]!='*')
			{
				if(dep[nx][ny]==-1)
				{
					dep[nx][ny]=dep[x][y]+1;
					que.push({nx,ny}) ;
				} 
				nx+=dx[i];
				ny+=dy[i];
			} 
		}
	}
	cout<<dep[n][m];
	return 0;
}