20分求调
查看原帖
20分求调
1376899
Powerful_K楼主2025/2/3 23:52
#include<bits/stdc++.h>
using namespace std;
int n,m,lx,ly,a,b,c,ux,uy;
struct guji{
	int x,y;
};
guji u,tmp,note;
queue<guji> q;
int ans[410][410];
int walk[8][2]={{2,1},{2,-1},{-2,1},{-2,-1},{1,-2},{1,2},{-1,-2},{-1,2}};
int main(){
	memset(ans,-1,sizeof(ans));
	cin >> n >> m >> lx >> ly;
	note={lx,ly};
	q.push(note);
	ans[lx][ly]=0;
	while(!q.empty()){
		u=q.front();
		ux=u.x;
		uy=u.y;
		q.pop();
		for(int i=0;i<8;i++){
			a=ux+walk[i][0];
			b=uy+walk[i][1];
			c=ans[ux][uy];
			if(a<1||a>n||b<1||b>n||ans[a][b]!=-1){
				continue;
			}
			ans[a][b]=c+1;
			tmp={a,b};
			q.push(tmp);
		}
	}
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			cout << ans[i][j] << "    ";
		}
		cout << endl;
	}
	return 0;
}
2025/2/3 23:52
加载中...