博客
关于我
LeetCode--(BFS)二进制矩阵中的最短路径
阅读量:164 次
发布时间:2019-02-28

本文共 2550 字,大约阅读时间需要 8 分钟。

深度搜索和广度搜索在二进制矩阵中的应用

在计算机科学中,广度优先搜索(BFS)是一种常用的算法,广泛应用于树和图的遍历问题中。本文将探讨如何利用BFS解决二进制矩阵中的最短路径问题。

算法思想

广度优先搜索是一种层序遍历算法,能够有效地在图中找到最短路径。其核心思想是从起点出发,逐层扩展搜索,每一层遍历完毕后再向下一层进行扩展。这样,每次处理一层节点时,路径长度加1,这样第一次到达终点时,路径长度即为最短路径。

在本题中,二进制矩阵中的每个单元格代表一个节点,相邻单元格则代表节点之间的边。由于矩阵中的路径要求所有经过的单元格值为0,且路径可以在8个方向移动,因此我们需要对每个可移动的方向进行检查。

代码实现

以下是实现该算法的Java代码:

import java.util.*;public class Solution {    public int shortestPathBinaryMatrix(int[][] grid) {        // 检查输入是否有效        if (grid == null || grid.length == 0 || grid[0].length == 0) {            return -1;        }        int m = grid.length;        int n = grid[0].length;        // 定义八个方向        int[][] directions = { {-1, -1}, {-1, 0}, {-1, 1},                                {0, -1},          {0, 1},                                {1, -1},  {1, 0}, {1, 1} };        // 使用队列实现BFS        Queue
> queue = new LinkedList<>(); queue.add(new Pair<>(0, 0)); // 记录路径长度 int pathlength = 0; while (!queue.isEmpty()) { int size = queue.size(); pathlength++; // 处理当前层的所有节点 while (size > 0) { Pair
current = queue.poll(); int currentRow = current.getKey(); int currentCol = current.getValue(); // 如果当前节点是终点,返回路径长度 if (currentRow == m - 1 && currentCol == n - 1) { return pathlength; } // 标记已访问的节点 grid[currentRow][currentCol] = 1; // 遍历八个方向,检查邻居是否在矩阵范围内 for (int[] direction : directions) { int newRow = currentRow + direction[0]; int newCol = currentCol + direction[1]; // 检查新坐标是否有效 if (newRow >= 0 && newRow < m && newCol >= 0 && newCol < n) { queue.add(new Pair<>(newRow, newCol)); } } } } // 如果未找到终点,返回-1 return -1; }}// 辅助类,用于存储坐标对private static class Pair
extends AbstractMap.Entry
{ Pair(T1 t1, T2 t2) { put(t1, t2); }}

代码解释

  • 输入检查:首先检查输入的二进制矩阵是否为空或任何维度为空,若为空则返回-1。

  • 方向定义:定义了八个方向的数组direction,表示从当前节点可以移动到的八个相邻节点。

  • 队列初始化:使用一个队列来存储当前层次的节点,起点(0,0)被加入队列。

  • BFS循环:队列不为空时,逐层处理节点。每次循环开始时,记录当前层次的节点数size,并增加路径长度。

  • 处理每个节点:逐个提取队列中的节点,检查是否为终点。如果是终点,返回当前路径长度。否则,将该节点标记为已访问,并将其邻居节点加入队列。

  • 邻居检查:遍历八个方向,检查新坐标是否在矩阵范围内。如果在,邻居节点被加入队列。

  • 终点检查:如果终点未被访问到,返回-1。

  • 总结

    通过上述方法,我们可以高效地找到二进制矩阵中的最短路径。BFS算法的层序遍历特性使其在求解最短路径问题上非常有效。代码实现详细地处理了每个节点的扩展,确保了路径的最短性和正确性。

    转载地址:http://lpwc.baihongyu.com/

    你可能感兴趣的文章
    Openlayers中点击地图获取坐标并输出
    查看>>
    Openlayers中设置定时绘制和清理直线图层
    查看>>
    Openlayers图文版实战,vue项目从0到1做基础配置
    查看>>
    Openlayers实战:modifystart、modifyend互动示例
    查看>>
    Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
    查看>>
    Openlayers高级交互(16/20):两个多边形的交集、差集、并集处理
    查看>>
    Openlayers高级交互(17/20):通过坐标显示多边形,计算出最大幅宽
    查看>>
    Openlayers高级交互(19/20): 地图上点击某处,列表中显示对应位置
    查看>>
    Openlayers高级交互(8/20):选取feature,平移feature
    查看>>
    openlayers:圆孔相机根据卫星经度、纬度、高度、半径比例推算绘制地面的拍摄的区域
    查看>>
    OpenLDAP(2.4.3x)服务器搭建及配置说明
    查看>>
    OpenLDAP编译安装及配置
    查看>>
    OpenMCU(一):STM32F407 FreeRTOS移植
    查看>>
    OpenMCU(三):STM32F103 FreeRTOS移植
    查看>>
    OpenMCU(二):GD32E23xx FreeRTOS移植
    查看>>
    OpenMetadata 命令执行漏洞复现(CVE-2024-28255)
    查看>>
    OpenMMLab | S4模型详解:应对长序列建模的有效方法
    查看>>
    OpenMMLab | 【全网首发】Llama 3 微调项目实践与教程(XTuner 版)
    查看>>
    OpenMMLab | 面向多样应用需求,书生·浦语2.5开源超轻量、高性能多种参数版本
    查看>>
    OpenMV入门教程(非常详细)从零基础入门到精通,看完这一篇就够了
    查看>>