基础算法: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
相关推荐
先吃饱再说17 小时前
判断回文字符串,从一行代码到双指针优化
算法
见过夏天17 小时前
C++ 基础入门完全指南
c++
黄敬峰20 小时前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术21 小时前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六1 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术1 天前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize1 天前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考2 天前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
CSharp精选营2 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型