美文网首页数据结构与算法
剑指 Offer 12 矩阵中的路径

剑指 Offer 12 矩阵中的路径

作者: itbird01 | 来源:发表于2021-12-23 07:09 被阅读0次
题目.png

题意:给定一个 m x n 二维字符网格 board 和一个字符串单词 word 。如果 word 存在于网格中,返回 true ;否则,返回 false 。
单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中“相邻”单元格是那些水平相邻或垂直相邻的单元格。同一个单元格内的字母不允许被重复使用。

解题思路

解法1:
1.分析题意,解决好像很简单,只需要用DFS or BFS 去搜索出来所有路径,然后判断路径是否包含结果字符串即可
2.但是容易超时,需要考虑,如何剪枝,这里我们把寻找到路径,作为flag存储起来,之后就不必要进行重新走了
3.DFS的重点在于,针对于每个位置,进行遍历前,需要将其状态值临时保存下来,然后标记为走过,等上下左右都走过之后,此位置状态值还原

解题遇到的问题

后续需要总结学习的知识点

##解法1
class Solution {
    boolean flag = false;

    public boolean exist(char[][] board, String word) {
        if (word == null) {
            return true;
        }

        int m = board.length;
        int n = board[0].length;
        char[] words = word.toCharArray();
        for (int i = 0; i < m; i++) {
            for (int j = 0; j < n; j++) {
                if (flag) {
                    break;
                }
                dfs(board, words, i, j, m, n, 0);
            }
        }
        return flag;
    }

    private void dfs(char[][] board, char[] words, int i, int j, int m, int n,
            int k) {
        if (flag) {
            return;
        }
        // 越界处理,回退
        if (i < 0 || i >= m || j < 0 || j >= n || board[i][j] != words[k]) {
            return;
        }

        if (k == words.length - 1) {
            // 找到答案,标记,回退
            flag = true;
            return;
        }

        // 先标记,用于后面回退
        char c = board[i][j];
        // 千万别忘记这步,需要把标记位走过
        board[i][j] = '*';
        dfs(board, words, i, j - 1, m, n, k + 1);
        dfs(board, words, i + 1, j, m, n, k + 1);
        dfs(board, words, i, j + 1, m, n, k + 1);
        dfs(board, words, i - 1, j, m, n, k + 1);
        // 回退标记位
        board[i][j] = c;
    }

}

相关文章

  • ARTS 20201218-1231

    Algorithm: 每周至少做一个 LeetCode 的算法题剑指 Offer 12. 矩阵中的路径[https...

  • 剑指 Offer 12 矩阵中的路径

    题意:给定一个 m x n 二维字符网格 board 和一个字符串单词 word 。如果 word 存在于网格中,...

  • [剑指offer] 矩阵中的路径

    本文首发于我的个人博客:尾尾部落 题目描述 请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的...

  • 剑指offer——矩阵中的路径

    题目描述 请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径。路径可以从矩阵中的任意一个格...

  • 剑指offer 矩阵中的路径

    思想:标准的回溯法实现: 使用hash表标记元素是否已经被访问 使用全局变量以及在函数内定义函数尽量减少代码量

  • 矩阵中的路径

    《剑指offer》面试题12:矩阵中的路径 题目:请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有...

  • 剑指 Offer 12. 矩阵中的路径

    和求岛屿的数量那类型题一样,都是利用了dfs和回溯 在回溯的时候,将board[i][j]沉没后,记得在dfs后要恢复

  • 剑指 Offer 12. 矩阵中的路径

    题目 请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径。路径可以从矩阵中的任意一格开始,...

  • 【剑指offer】问题12:矩阵中的路径

    题目:请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径。路径可以从矩阵中的任意一个格子开...

  • 剑指offer12_矩阵中的路径

    题目描述 请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径。路径可以从矩阵中的任意一个格...

网友评论

    本文标题:剑指 Offer 12 矩阵中的路径

    本文链接:https://www.haomeiwen.com/subject/kuxcqrtx.html