大佬求条,玄关
查看原帖
大佬求条,玄关
1272214
luozihang楼主2025/1/24 18:32

话不多说,上代码!

#include<bits/stdc++.h>
using namespace std;
int n,m,dis[10001][1001],sx,sy,fx,fy;
char g[1001][1001];
bool vis[1001][1001];
int dx[]={-1,1,0,0},dy[]={0,0,-1,1};
void bfs(int sx,int sy){
	queue<int> qx,qy;
	qx.push(sx);
	qy.push(sy);
	vis[sx][sy]=1;
	dis[sx][sy]=1;
	while(qx.size()){
		int x=qx.front(),y=qy.front();
		qx.pop(),qy.pop();
		for(int i=0;i<=3;i++){
			int nx=x+dx[i],ny=y+dy[i];
			if(nx>=1&&nx<=n&&ny>=1&&ny<=n&&!g[nx][ny]&&!vis[nx][ny]){
				vis[nx][ny]=1;
				dis[nx][ny]=dis[x][y]+1;
				qx.push(nx),qy.push(ny);
			}
		}
	}
}
int main(){
	cin>>n;
	for(int i=1;i<=n;i++){
		for(int j=1;j<=n;j++){
			cin>>g[i][j];
		}
	}
	cin>>sx>>sy>>fx>>fy;
	bfs(sx,sy);
	cout<<dis[fx][fy];
	return 0;
}

玄关......

2025/1/24 18:32
加载中...