【洛谷 P1443】马的遍历 题解(广度优先搜索)
创始人
2024-05-30 22:15:53

马的遍历

题目描述

有一个 n×mn \times mn×m 的棋盘,在某个点 (x,y)(x, y)(x,y) 上有一个马,要求你计算出马到达棋盘上任意一个点最少要走几步。

输入格式

输入只有一行四个整数,分别为 n,m,x,yn, m, x, yn,m,x,y。

输出格式

一个 n×mn \times mn×m 的矩阵,代表马到达某个点最少要走几步(不能到达则输出 −1-1−1)。

样例 #1

样例输入 #1

3 3 1 1

样例输出 #1

0    3    2    
3    -1   1    
2    1    4

提示

数据规模与约定

对于全部的测试点,保证 1≤x≤n≤4001 \leq x \leq n \leq 4001≤x≤n≤400,1≤y≤m≤4001 \leq y \leq m \leq 4001≤y≤m≤400。

思路

  1. 马走“日”
  2. 输出格式:域宽为5,左对齐
  3. 注意判断是否越界

AC代码

#include 
#include 
#include 
#define AUTHOR "HEX9CF"
using namespace std;const int maxn = 405;
const int sun[8][2] = {-2, 1, -2, -1, -1, 2, -1, -2, 2, 1, 2, -1, 1, 2, 1, -2};
int n, m, x, y;bool vis[maxn][maxn];
int stp[maxn][maxn];
queue> q;void bfs(int x, int y)
{vis[x][y] = 1;stp[x][y] = 0;q.push(make_pair(x, y));while (!q.empty()){pair f = q.front();q.pop();for (int i = 0; i < 8; i++){int xx = f.first + sun[i][0];int yy = f.second + sun[i][1];if (xx > 0 && xx <= n && yy > 0 && yy <= m && !vis[xx][yy]){vis[xx][yy] = 1;q.push(make_pair(xx, yy));stp[xx][yy] = stp[f.first][f.second] + 1;}}}
}int main()
{memset(vis, 0, sizeof(vis));memset(stp, -1, sizeof(stp));cin >> n >> m >> x >> y;stp[x][y] = 0;vis[x][y] = true;q.push(make_pair(x, y));bfs(x, y);for (int i = 1; i <= n; i++){for (int j = 1; j <= m; j++){printf("%-5d", stp[i][j]);}putchar('\n');}return 0;
}

相关内容

热门资讯

春节给家里选电视还是换投影一文... 【ZOL原创技术】春节的脚步越来越近,家家户户都在忙着焕新家居、筹备团圆,而客厅作为全家欢聚的核心场...
台股开红盘在即,ETF规模翻倍... 经济观察网 截至2026年2月19日,台湾基金与股票市场近期值得关注的事件集中于台股长假后开红盘、E...
联合国强烈谴责以色列在约旦河西... 来源:央视新闻客户端当地时间2月18日,联合国巴勒斯坦人民行使不可剥夺权利委员会主席团发表声明,强烈...
2026年第一季度四大通信手机... 【ZOL中关村在线原创导购】进入2026年第一季度,手机行业的通信技术迎来了新一轮的升级突破,卫星通...
AMD Zen 6架构APU将... 【ZOL中关村在线原创新闻】近日,AMD 在提交给 LLVM 编译器的驱动代码中,披露了即将应用于Z...