博客
关于我
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/

    你可能感兴趣的文章
    PDO中捕获SQL语句中的错误
    查看>>
    SCP和SFTP相同点和区别
    查看>>
    SpringCloudAlibaba中使用Sentinel实现熔断降级之熔断策略详解
    查看>>
    peek和pop的区别
    查看>>
    Pelemay 项目教程
    查看>>
    Penetration Testing、Security Testing、Automation Testing
    查看>>
    Pentaho业务分析平台 SQL注入漏洞复现
    查看>>
    PentestGPT:一款由ChatGPT驱动的强大渗透测试工具
    查看>>
    PeopleTools 8.54 first install note
    查看>>
    PEP 8016 获胜,成为新的 Python 社区治理方案
    查看>>
    PEP8规范
    查看>>
    PEPM Cookie 远程代码执行漏洞复现(XVE-2024-16919)
    查看>>
    Percona Server 5.6 安装TokuDB
    查看>>
    SpringBoot(十四)整合MyBatis
    查看>>
    percona-xtrabackup 备份
    查看>>
    Perfect,华为爆出 Redis 宝典,原来 Redis 性能可压榨到极致
    查看>>
    SpringBoot集成OpenOffice实现doc文档转html
    查看>>
    Perl Socket传输(带注释)
    查看>>
    ROS中机器人的强化学习路径规划器
    查看>>
    perl---2012学习笔记
    查看>>