50求调
查看原帖
50求调
550830
宋欣龙楼主2024/10/23 22:10
#include<queue>
#include<cmath>
#include<cstdio>
#include<vector>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
const int N=410;
int dx[8]={-1,-2,-2,-1,1,2,2,1};
int dy[8]={2,1,-1,-2,2,1,-1,-2};
int n,m,x,y;
bool vis[N][N];
int ans[N][N];
struct edge{
	int x,y;
};
queue<edge>q;
int bfs(int a,int b){
	edge e;e.x=a;e.y=b;q.push(e);
	while(!q.empty()){
		edge st=q.front();q.pop();
		for(int i=0;i<8;i++){
			edge nx;nx.x=st.x+dx[i];nx.y=st.y+dy[i];
			if(nx.x>=1&&nx.x<=n&&nx.y>=1&&nx.y<=m&&vis[nx.x][nx.y]==0){
				vis[nx.x][nx.y]=1;
				ans[nx.x][nx.y]=ans[st.x][st.y]+1;
				q.push(nx);
			}
		}
	}
}
int main(){
	std::ios::sync_with_stdio(0);
	cin.tie(0),cout.tie(0);
	cin>>n>>m>>x>>y;
	memset(ans,-1,sizeof(ans));
	ans[x][y]=0;vis[x][y]=1;
	bfs(x,y);
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			printf("%-5d",ans[i][j]);
		}cout<<endl;
	}
	return 0;
}
2024/10/23 22:10
加载中...