社区讨论
求助大佬,为什么全是RE?
P1443马的遍历参与者 3已保存回复 4
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 4 条
- 当前快照
- 1 份
- 快照标识符
- @m60hpmy8
- 此快照首次捕获于
- 2025/01/17 16:20 去年
- 此快照最后确认于
- 2025/01/17 19:39 去年
CPP
#include<bits/stdc++.h>
using namespace std;
int main(){
queue<int> qx,qy;
int map[402][402];
int dx[8]={1,-1,-1,1,2,-2,-2,2};
int dy[8]={2,-2,2,-2,1,-1,1,-1};
int n,m,x,y,nx,ny,t1,t2,i,j;
cin >> n >> m >> x >> y;
memset(map,-1,sizeof(map));
qx.push(x);
qy.push(y);
map[x][y]=0;
while (!qx.empty()){
for (i=0;i<=8;i++){
nx=qx.front()+dx[i];
ny=qy.front()+dy[i];
if (nx>=1 && nx<=n && ny>=1 && ny<=m && map[nx][ny]==-1){
map[nx][ny]=map[qx.front()][qy.front()]+1;
qx.push(nx);
qy.push(ny);
}
}
qx.pop();
qy.pop();
}
for (i=1;i<=n;i++){
for (j=1;j<=m;j++)
cout << map[i][j] << " ";
cout << endl;
}
return 0;
}
回复
共 4 条回复,欢迎继续交流。
正在加载回复...