当前位置: 首页 > article >正文

173. 矩阵距离 acwing -多路BFS

原题链接:173. 矩阵距离 - AcWing题库

给定一个 N行 M 列的 01矩阵 A,A[i][j] 与 A[k][l]]之间的曼哈顿距离定义为:

dist(i,j,k,l)=|i−k|+|j−l||

输出一个 N 行 M 列的整数矩阵 B,其中:

B[i][j]=min1≤x≤N,1≤y≤M,A[x][y]=1dist(i,j,x,y)

输入格式

第一行两个整数 N,M

接下来一个 N 行 M 列的 01 矩阵,数字之间没有空格。

输出格式

一个 NN 行 MM 列的矩阵 B,相邻两个整数之间用一个空格隔开。

数据范围

1≤N,M≤1000

输入样例:
3 4
0001
0011
0110
输出样例:
3 2 1 0
2 1 0 0
1 0 0 1

 

#include<iostream>
#include<algorithm>
#include<cstring>

// 定义宏,方便使用pair的first和second成员
#define x first
#define y second

using namespace std;

// 定义一个pair<int, int>类型的别名PII
typedef pair<int,int> PII;

// 定义常量N和M,N表示网格的最大行数,M表示队列的最大大小
const int N = 1010, M = N*N;

// 定义全局变量n和m,分别表示网格的行数和列数
int n, m;

// 定义一个二维字符数组g,用于存储网格中的字符
char g[N][N];

// 定义一个队列q,用于广度优先搜索
PII q[M];

// 定义一个二维整数数组dist,用于存储每个位置到最近的'1'的距离
int dist[N][N];

// 定义广度优先搜索函数bfs
void bfs()
{
    // 初始化dist数组,所有位置的距离设为-1
    memset(dist, -1, sizeof dist);
    
    // 定义队列的头指针hh和尾指针tt
    int hh = 0, tt = -1;
    
    // 遍历整个网格,将所有值为'1'的位置加入队列,并将它们的距离设为0
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < m; j++)
        {
            if (g[i][j] == '1')
            {
                dist[i][j] = 0;
                q[++tt] = {i, j};
            }
        }
    }
    
    // 定义四个方向的移动数组dx和dy
    int dx[4] = {-1, 0, 1, 0}, dy[4] = {0, 1, 0, -1};
    
    // 开始广度优先搜索
    while (hh <= tt)
    {
        // 取出队列头部元素
        auto t = q[hh++];
        
        // 遍历四个方向
        for (int i = 0; i < 4; i++)
        {
            // 计算新位置的坐标
            int a = t.x + dx[i], b = t.y + dy[i];
            
            // 如果新位置超出网格范围,则跳过
            if (a < 0 || a >= n || b < 0 || b >= m) continue;
            
            // 如果新位置已经访问过,则跳过
            if (dist[a][b] != -1) continue;
            
            // 更新新位置的距离,并将其加入队列
            dist[a][b] = dist[t.x][t.y] + 1;
            q[++tt] = {a, b};
        }
    }
}

// 主函数
int main()
{
    // 读取网格的行数和列数
    scanf("%d %d", &n, &m);
    
    // 读取网格中的字符
    for (int i = 0; i < n; i++)
    {
        scanf("%s", g[i]);
    }
    
    // 调用广度优先搜索函数
    bfs();
    
    // 输出每个位置到最近的'1'的距离
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < m; j++)
        {
            printf("%d ", dist[i][j]);
        }
        printf("\n");
    }
    
    return 0;
}


http://www.kler.cn/a/464405.html

相关文章:

  • Rocketmq 探索MQClientFactoryScheduledThread线程工作
  • 现代前端框架
  • nginx学习之路-nginx配置https服务器
  • c# Record关键字
  • RK3588+麒麟国产系统+FPGA+AI在电力和轨道交通视觉与采集系统的应用
  • Jetpack Compose 学习笔记(四)—— CompositionLocal 与主题
  • 【 IEEE 独立出版 · EI核心、Scopus稳定检索 】第二届算法、软件工程与网络安全国际学术会议(ASENS 2025)
  • Hive集成Iceberg碰到的问题
  • Bash 中的 2>1 | tee 命令详解
  • java实现预览服务器文件,不进行下载,并增加水印效果
  • 《Vue3实战教程》37:Vue3生产部署
  • 【SpringBoot教程】搭建SpringBoot项目之编写pom.xml
  • 《Java 数据结构》
  • spring-boot启动源码分析(二)之SpringApplicationRunListener
  • redis的学习(一)
  • 【人工智能机器学习基础篇】——深入详解无监督学习之聚类,理解K-Means、层次聚类、数据分组和分类
  • Flutter:邀请海报,Widget转图片,保存相册
  • 快递物流查询API接口推荐
  • 操作018:Stream Queue
  • 【2025优质学术推荐】征稿控制科学、仪器、智能系统、通信、计算机、电子信息、人工智能、大数据、机器学习、软件工程、网络安全方向
  • Leetcode打卡:分割数组
  • 使用 Python结合ffmpeg 实现单线程和多线程推流
  • 婚庆摄影小程序ssm+论文源码调试讲解
  • UE5.3 虚幻引擎 Windows插件开发打包(带源码插件打包、无源码插件打包)
  • 神经网络入门实战:(二十三)使用本地数据集进行训练和验证
  • Qt使用CMake编译项目时报错:#undefined reference to `vtable for MainView‘