基础算法:BFS

#搜索 #基础算法

宽度优先搜索 BFS

(层次扩展+队列+边权为1的最短路)

核心思想

  • 从起点出发,一层一层向外扩散;先到的层就是最短路径

模板

cpp 复制代码
void bfs()
{
    memset(dist, -1, sizeof dist);
    queue<PII> q;
    q.push({x, y});               // 插入队列
    dist[x][y] = 0;               // 起始节点初始化为 0

    while (q.size())
    {
        auto t = q.front(); q.pop();      // 拿出后删掉队头
        for (int k = 0; k < 8; k++)       // 八个方向遍历
        {
            int i = t.first, j = t.second;
            int x = i + dx[k], y = j + dy[k];
            if (x < 1 || x > n || y < 1 || y > m) continue;   // 越界剪枝
            if (dist[x][y] != -1) continue;                   // 访问过剪枝
            dist[x][y] = dist[i][j] + 1;                      // 更新结果
            q.push({x, y});                                   // 插入队尾
        }
    }
}

多源BFS

初始化:

cpp 复制代码
for 所有起点 p
    dist[p] = 0, q.push(p);

//其余代码与单源完全一致;第一次访问即最短距离。

01-BFS(边权只有0或1)

  • 0 权边 → 插队头 push_front
  • 1 权边 → 插队尾 push_back
  • 用双端队列 deque ,仍保证"层"有序
  • 复杂度 O(V+E)。
cpp 复制代码
int dfs01(int x1, int y1, int x2, int y2) {
    memset(dist, -1, sizeof dist);              // 距离表初始化为"未访问"
    deque<pair<int, int>> q;                    // 双端队列:0 权头插,1 权尾插
    q.push_back({x1, y1});                      // 起点入队
    dist[x1][y1] = 0;                           // 起点代价 0

    while (q.size()) {
        auto [x, y] = q.front(); q.pop_front(); // 取出当前最小代价节点
        if (x == x2 && y == y2) return dist[x][y]; // 到达终点,立即返回最短路

        for (int k = 0; k < 4; k++) {           // 四方向扩展
            int nx = x + dx[k], ny = y + dy[k]; // 邻居坐标
            if (nx < 1 || nx > n || ny < 1 || ny > m) continue; // 越界剪枝
            if (dist[nx][ny] != -1) continue;   // 已访问剪枝

            int w = (g[nx][ny] == g[x][y] ? 0 : 1); // 边权:相同 0,不同 1
            dist[nx][ny] = dist[x][y] + w;      // 更新邻居距离
            if (w == 0) q.push_front({nx, ny}); // 0 权边插队头
            else q.push_back({nx, ny});         // 1 权边排队尾
        }
    }
    return -1;  // 无法到达终点
}

常见应用对照表

问题 关键词 算法
迷宫最短路 边权1 单源BFS
矩阵多起点 多源最短路 多源BFS
走到相邻格代价0/1 0-1边权 01-BFS
层次遍历,联通块 层序扩散 BFS
相关推荐
赫瑞8 小时前
数据结构中的排列组合 —— Java实现
java·开发语言·数据结构
大熊背9 小时前
ISP Pipeline中Lv实现方式探究之三--lv计算定点实现
数据结构·算法·自动曝光·lv·isppipeline
小橘子8319 小时前
(学习)Claude Code 源码架构深度解析
学习·程序人生·架构
初夏睡觉9 小时前
c++1.3(变量与常量,简单数学运算详解),草稿公放
开发语言·c++
升职佳兴9 小时前
C盘爆满自救:3步无损迁移应用数据到E盘(含回滚)
c语言·开发语言
ID_180079054739 小时前
除了 Python,还有哪些语言可以解析 JSON 数据?
开发语言·python·json
西岸行者9 小时前
BF信号是如何多路合一的
算法
阿拉斯攀登9 小时前
从入门到实战:CMake 与 Android JNI/NDK 开发全解析
android·linux·c++·yolo·cmake
大熊背10 小时前
ISP Pipeline中Lv实现方式探究之一
算法·自动白平衡·自动曝光
周末也要写八哥10 小时前
多进程和多线程的特点和区别
java·开发语言·jvm