本蒟蒻样例没过,咳咳,上代码。。。
#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=1;i<=sx;i++){
for(int j=1;j<=sy;j++){
cout<<dis[i][j]<<setw(5);
}
cout<<"\n";
}
return 0;
}