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

    你可能感兴趣的文章
    Objective-C实现弧度到度算法 (附完整源码)
    查看>>
    Objective-C实现循环链表(附完整源码)
    查看>>
    Objective-C实现循环队列算法(附完整源码)
    查看>>
    Objective-C实现循环队列链表算法(附完整源码)
    查看>>
    Objective-C实现快速排序算法(附完整源码)
    查看>>
    Objective-C实现恩尼格玛密码机算法(附完整源码)
    查看>>
    Objective-C实现感知哈希算法(附完整源码)
    查看>>
    Objective-C实现感知哈希算法(附完整源码)
    查看>>
    Objective-C实现截留雨水问题的动态编程方法算法(附完整源码)
    查看>>
    Objective-C实现截留雨水问题的蛮力方法的算法(附完整源码)
    查看>>
    Objective-C实现打印10000以内的完数(附完整源码)
    查看>>
    Objective-C实现打印1000以内的水仙花数(附完整源码)
    查看>>
    Objective-C实现打印九九乘法表(附完整源码)
    查看>>
    Objective-C实现打印从 0 到 n 的卡特兰数算法(附完整源码)
    查看>>
    Objective-C实现打印函数调用堆栈( 附完整源码)
    查看>>
    Objective-C实现打印杨辉三角(附完整源码)
    查看>>
    Objective-C实现打印某年的历法日期(附完整源码)
    查看>>
    Objective-C实现打印魔方矩阵(附完整源码)
    查看>>
    Objective-C实现打格点算法(附完整源码)
    查看>>
    Objective-C实现批量修改文件类型算法(附完整源码)
    查看>>