剑指 Offer 12. 矩阵中的路径

题目描述

给定一个 m x n 二维字符网格 board 和一个字符串单词 word 。如果 word 存在于网格中,返回 true ;否则,返回 false

单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中"相邻"单元格是那些水平相邻或垂直相邻的单元格。同一个单元格内的字母不允许被重复使用。

解题思路

方法一:深度优先搜索+剪枝

利用递归,从第一个元素开始,查询临近的四个方向上的元素是否符合要求,若第(i,j)个元素符合则检测该元素四个方向上的元素,不断延申,直到找到字符串或者返回没找到结束递归。

递归返回条件:

根据二维数组四个角的下标(0,0),(rows,0),(rows,cols),(0,cols),我们可以得到当横向边界小于0或者>=rows时,证明已经全部查询完毕;纵向边界<0或者>=cols,证明已经全部查询完毕,并且没有查询到字符串,返回false。(当二维数组有3列时,下标是0,1,2,因此当>=rows时表示已经越界了)

在匹配字符串时,每次匹配一个字符,当我们成功匹配字符串的最后一个时表示查找到了字符串,返回true。

然而在这种情况下会有一种情况,比如在下表中查找"ABCHHHD":

|---|---|---|---|
| A | B | C | D |
| M | A | H | D |
| D | E | H | F |
| U | D | H | I |

我们从A开始,到B,到C,到H,到H ,此时我们已经到达下面的位置:

下一个要寻找的应该是下面的H,可是对于上述情况来说,如果代码中,向上寻找先于向下寻找,那么就会回到上面的H。因此我们需要在本次递归过程中标记已经访问过的元素。因此我们将访问过的并且成功匹配的字符更改内容为'\0',退出本次递归时再还原回去。(因为其他的递归中可能并没有访问这个元素)

代码

cpp 复制代码
class Solution
{
private:
	int rows;
	int cols;
	bool DFS(std::vector<std::vector<char>>& board, std::string word, int i, int j, int k)
    {
        if (i >= rows || i < 0 || j >= cols || j < 0 || board[i][j] != word[k])
                return false;
        if (k == word.size() - 1)
            return true;
        board[i][j] = '\0';
        bool res = DFS(board, word, i + 1, j, k + 1) ||
        DFS(board, word, i - 1, j, k + 1) ||
        DFS(board, word, i, j + 1, k + 1) ||        
        DFS(board, word, i, j - 1, k + 1);
        board[i][j] = word[k];
        return res;    
    }
public:
    bool Solution::exist(std::vector<std::vector<char>>& board, std::string word)
    {
        rows = board.size();
        cols = board[0].size();
        for (int i = 0; i < rows; i++) {
            for (int j = 0; j < cols; j++) {
                if (DFS(board, word, i, j, 0)) return true;
            }
        }
        return false;
    }
};
相关推荐
王_teacher9 小时前
机器学习 矩阵求导 完整公式+严谨推导
人工智能·线性代数·考研·机器学习·矩阵·线性回归
做cv的小昊17 小时前
【TJU】研究生应用统计学课程笔记(2)——第一章 数理统计的基本知识(1.3 统计中常用的分布族)
笔记·线性代数·数学建模·矩阵·概率论·学习方法·抽象代数
二等饼干~za89866821 小时前
GEO 源码部署搭建详细操作教程(2026 最新版)
线性代数·django·开源·音视频·ai-native
Pentane.1 天前
【力扣hot100】【Leetcode 54】螺旋矩阵|边界控制 算法笔记及打卡(19/100)
算法·leetcode·矩阵
博.闻广见1 天前
AI_线性代数-6.PCA降维详解
人工智能·线性代数
做cv的小昊1 天前
【TJU】研究生应用统计学课程笔记(3)——第一章 数理统计的基本知识(1.4 正态总体的样本均值和样本方差的分布、1.5 充分统计量和完备统计量)
笔记·学习·线性代数·机器学习·数学建模·概率论
mxwin1 天前
Unity URP 下 TBN 矩阵学习 切线空间、tangent.w 与镜像 UV 的那些坑
学习·unity·矩阵·shader
Dxy12393102161 天前
Elasticsearch 8 如何进行二维矩阵向量搜索
大数据·elasticsearch·矩阵
MediaTea1 天前
Scikit-learn:特征矩阵与目标变量
人工智能·python·机器学习·矩阵·scikit-learn
Jasmine_llq2 天前
《B4259 [GESP202503 二级] 等差矩阵》
线性代数·矩阵·顺序输入输出算法·双重循环遍历算法·行列乘积计算算法·矩阵逐行输出算法·空格分隔输出算法