博客
关于我
leetCode 79 单词搜索 (dfs,回溯)
阅读量:271 次
发布时间:2019-03-01

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

给定一个字母矩阵,所有的字母都与上下左右四个方向上的字母相连。给定一个字符串,求字符串能不能在字母矩阵中寻找到。

输入输出

输入:

  • board:一个二维向量,包含字符。
  • word:一个字符串。

输出:

  • 返回布尔值,表示是否存在。

分析

解决这个问题可以使用深度优先搜索(DFS)或广度优先搜索(BFS)算法。DFS 适用于这种问题,因为可以在同一个二维数组中进行状态修改,避免重复状态。

代码

bool exist(vector
>& board, string word) { if (board.empty() || word.empty()) return false; int m = board.size(), n = board[0].size(); vector
> visited(m, vector
(n, false)); bool found = false; for (int i = 0; i < m; ++i) { for (int j = 0; j < n; ++j) { if (backtracking(i, j, board, word, found, visited, 0)) { return true; } } } return found;}void backtracking(int i, int j, vector
>& board, string& word, bool& found, vector
>& visited, int pos) { if (i < 0 || i >= board.size() || j < 0 || j >= board[0].size()) { return; } if (visited[i][j] || found || board[i][j] != word[pos]) { return; } if (pos == word.size() - 1) { found = true; return; } visited[i][j] = true; if (backtracking(i + 1, j, board, word, found, visited, pos + 1)) { return; } visited[i][j] = false; if (backtracking(i - 1, j, board, word, found, visited, pos + 1)) { return; } visited[i][j] = false; if (backtracking(i, j + 1, board, word, found, visited, pos + 1)) { return; } visited[i][j] = false; if (backtracking(i, j - 1, board, word, found, visited, pos + 1)) { return; } visited[i][j] = false;}

代码解释

  • exist函数:这是主函数,负责初始化和调用回溯函数。

    • 检查边界条件:如果矩阵或字符串为空,返回false。
    • 创建访问数组visited,记录每个位置是否被访问过。
    • 遍历矩阵中的每一个单元格作为起点,调用回溯函数。
    • 如果回溯函数返回true,说明找到字符串,返回true。
  • backtracking函数:实现深度优先搜索。

    • 检查是否越界:如果越界,返回false。
    • 检查当前单元格是否已访问或字符不匹配:如果是,返回false。
    • 如果到达字符串末尾,返回true。
    • 标记当前单元格为已访问,递归四个方向。
    • 递归返回后,恢复当前单元格状态为未访问。
  • 这种方法确保每个位置只被访问一次,避免重复状态,提高效率。

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

    你可能感兴趣的文章
    Objective-C 编码规范
    查看>>
    Objective-Cfor循环实现Factorial阶乘算法 (附完整源码)
    查看>>
    Objective-C——判断对象等同性
    查看>>
    objective-c中的内存管理
    查看>>
    Objective-C之成魔之路【7-类、对象和方法】
    查看>>
    Objective-C享元模式(Flyweight)
    查看>>
    Objective-C以递归的方式实现二叉搜索树算法(附完整源码)
    查看>>
    Objective-C内存管理教程和原理剖析(三)
    查看>>
    Objective-C实现 Greedy Best First Search最佳优先搜索算法(附完整源码)
    查看>>
    Objective-C实现 jugglerSequence杂耍者序列算法 (附完整源码)
    查看>>
    Objective-C实现 lattice path格子路径算法(附完整源码)
    查看>>
    Objective-C实现1000 位斐波那契数算法(附完整源码)
    查看>>
    Objective-C实现2 个数字之间的算术几何平均值算法(附完整源码)
    查看>>
    Objective-C实现2d 表面渲染 3d 点算法(附完整源码)
    查看>>
    Objective-C实现2D变换算法(附完整源码)
    查看>>
    Objective-C实现3n+1猜想(附完整源码)
    查看>>
    Objective-C实现3n+1猜想(附完整源码)
    查看>>
    Objective-C实现9x9乘法表算法(附完整源码)
    查看>>
    Objective-C实现9×9二维数组数独算法(附完整源码)
    查看>>
    Objective-C实现A*(A-Star)算法(附完整源码)
    查看>>