深度(迷宫)1

#include <iostream>
using namespace std;
int migong[10000][10000];int sx,sy,ex,ey;int flag=0;
void digui(int x,int y){
	if(x==ex&&y==ey){
		flag=1;return;
	}
	if(migong[x][y]==2){
		return;
	}
	migong[x][y]=2;
	if(migong[x-1][y]==1){
		digui(x-1,y);
	}
	if(migong[x+1][y]==1){
		digui(x+1,y);
	}
	if(migong[x][y+1]==1){
		digui(x,y+1);
	}
	if(migong[x][y-1]==1){
		digui(x,y-1);
	}
}
int main(){
	int n,m;
	cin>>n>>m;
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			char a;
			cin>>a;
			if(a=='S'){
				sx=i;sy=j;
				migong[i][j]=1;
			}
			if(a=='X'){
				migong[i][j]=0;
			}
			if(a=='.'){
				migong[i][j]=1;
			}
			if(a=='T'){
				ex=i;ey=j;
				migong[i][j]=1;
			}
		}
	}
	digui(sx,sy);
	if(flag){
		cout<<"YES";
	}
	else{
		cout<<"NO";
	}
}

  

上一篇:牛客算法周周练7-题解


下一篇:Greedy Snake 3.0