0pts求条,玄关
查看原帖
0pts求条,玄关
1272214
luozihang楼主2025/1/23 10:44

本蒟蒻样例没过,咳咳,上代码。。。

#include<bits/stdc++.h>
using namespace std;
int dis[1001][1001],n,m,sx,sy,fx,fy;
char g[1001][1001];
int dx[]={-1,-2,-2,-1,1,2,2,1};//方向数组 
int dy[]={-2,-1,1,2,2,1,-1,-2};
bool vis[1001][1001];
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<=7;i++){//进行拓展 
			int nx=x+dx[i],ny=y+dy[i];
			if(nx>=1&&nx<=sx&&ny>=1&&ny<=sy&&!vis[nx][ny]){
				dis[nx][ny]=dis[x][y]+1;
				vis[nx][ny]=1;
				qx.push(nx),qy.push(ny);
			}
		}
	}
}
int main(){
	ios::sync_with_stdio(0);
	cin.tie(0);
	cout.tie(0);
	cin>>sx>>sy>>fx>>fy;
	bfs(fx,fy);
	for(int i=0;i<sx;i++){//输出
		cout<<dis[i][0]; 
		for(int j=1;j<sy;j++){
			cout<<setw(5)<<dis[i][j];
		}
		cout<<"\n";
	}
	return 0;
}
2025/1/23 10:44
加载中...