AcWing算法提高课-2.3.1矩阵距离

算法提高课整理

CSDN个人主页:更好的阅读体验


本文同步发表于 CSDN | 洛谷 | AcWing | 个人博客

原题链接
题目描述

给定一个 01 矩阵,求矩阵中每个元素离 1 的最短曼哈顿距离。

输入格式

第一行两个整数 n , m n,m n,m。

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

输出格式

一个 n n n 行 m m m 列的矩阵,相邻数字之间用空格隔开。

数据范围

1 ≤ n , m ≤ 1000 1\le n,m\le 1000 1≤n,m≤1000


思路

先考虑从 0 的位置向外扩展。

发现这样的话较麻烦,于是改为考虑从 1 的位置用 BFS 向外扩展,并处理出所有的距离。

这种算法即为 "多源 BFS"。具体算法流程为:将所有源点都入队,然后正常跑 BFS。

具体细节见代码。

算法时间复杂度
AC Code

C + + \text{C}++ C++

cpp 复制代码
#include <iostream>
#include <cstring>
#include <queue>

using namespace std;

typedef pair<int, int> PII;
#define x first
#define y second

const int N = 1010;
int dx[] = {-1, 0, 1, 0};
int dy[] = {0, 1, 0, -1};

int n, m;
char g[N][N];
int dist[N][N];

void bfs()
{
    memset(dist, -1, sizeof dist);
    queue<PII> q;
    
    for (int i = 0; i < n; i ++ )
        for (int j = 0; j < m; j ++ )
            if (g[i][j] == '1')
                dist[i][j] = 0, q.push({i, j}); // 所有起点入队
    
    while (q.size())
    {
        PII t = q.front();
        q.pop();
        
        for (int i = 0; i < 4; i ++ ) // 4方向扩展
        {
            int x = t.x + dx[i], y = t.y + dy[i];
            if (x < 0 || x >= n || y < 0 || y >= m) continue; // 出界
            if (dist[x][y] != -1) continue; // 已经被遍历过
            dist[x][y] = dist[t.x][t.y] + 1; // 合法的话更新距离
            q.push({x, y}); // 新点入队
        }
    }
}

int main()
{
    scanf("%d%d", &n, &m);
    for (int i = 0; i < n; i ++ )
        scanf("%s", g[i]);
    
    bfs();
    
    for (int i = 0; i < n; i ++ )
    {
        for (int j = 0; j < m; j ++ )
            printf("%d ", dist[i][j]);
        puts("");
    }
    
    return 0;
}

最后,如果觉得对您有帮助的话,点个赞再走吧!

相关推荐
特种加菲猫23 分钟前
STL关联容器:Set/Multiset与Map/Multimap详解
开发语言·c++
Andy35 分钟前
C++ list容器基本逻辑结构详解
c++·windows·list
斯内科1 小时前
四胞胎素数:找出‌个位数分别是 1、3、7、9‌,且‌十位及更高位数字完全相同‌的质数,例如 11、13、17、19
算法·质数·素数·四胞胎素数
Hello.Reader2 小时前
算法基础(十二)——主方法:快速求解常见递归式
算法
想唱rap2 小时前
传输层协议TCP
linux·运维·服务器·网络·c++·tcp/ip
小O的算法实验室2 小时前
2026年IEEE TITS,面向按需外卖配送调度的特定问题知识与基于学习元启发式算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
加勒比海带662 小时前
目标检测算法——农林行业数据集汇总附下载链接【Plant】
大数据·图像处理·人工智能·算法·目标检测
洛水水2 小时前
【力扣100题】23. 螺旋矩阵
算法·leetcode·矩阵
瑶池酒剑仙2 小时前
C++类和对象完全指南:从封装继承多态到内存布局的面向对象宝典(雨夜论道)
c语言·开发语言·c++·visual studio
影sir3 小时前
不同测试数据下,该如何选择算法
算法·深度优先