123. 单词搜索(DFS)

Posted narjaja

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了123. 单词搜索(DFS)相关的知识,希望对你有一定的参考价值。

描述

给出一个二维的字母板和一个单词,寻找字母板网格中是否存在这个单词。
单词可以由按顺序的相邻单元的字母组成,其中相邻单元指的是水平或者垂直方向相邻。每个单元中的字母最多只能使用一次。

样例

给出
board =
[
"ABCE",
"SFCS",
"ADEE"]

word = "ABCCED", ->返回 true,
word = "SEE",-> 返回 true,
word = "ABCB", -> 返回 false.

class Solution {
public:
    /**
     * @param board: A list of lists of character
     * @param word: A string
     * @return: A boolean
     */
    bool exist(vector<vector<char>> &board, string &word) {
        // write your code here
                // write your code here
        vector< vector<bool> > mask(board.size(), vector<bool>(board[0].size(), false));
        for (int i=0; i<board.size(); ++i) {
            for (int j=0; j<board[0].size(); ++j) {
                if (search(board, word, mask, i, j, 0) ) {
                    return true;
                }
            }
        }
        return false;
    }
    
    bool search(vector< vector<char> >& board, string word, vector< vector<bool> >& mask, int i, int j, int idx) {
        if (word[idx]==board[i][j]) {
            mask[i][j] = true;
            ++idx;
            if (idx == word.size()) return true;
            else if (i-1>=0 && !mask[i-1][j] && search(board, word, mask, i-1, j, idx)) return true;
            else if (i+1< board.size() && !mask[i+1][j] && search(board, word, mask, i+1, j, idx)) return true;
            else if (j-1>=0 && !mask[i][j-1]&& search(board, word, mask, i, j-1, idx)) return true;
            else if (j+1< board[0].size() && !mask[i][j+1] && search(board, word, mask, i, j+1, idx)) return true;
            else {
                mask[i][j] = false;
                return false;
            }
        }
    }
};








以上是关于123. 单词搜索(DFS)的主要内容,如果未能解决你的问题,请参考以下文章

[dfs] aw1117. 单词接龙(dfs搜索顺序+递归理解+好题)

212. 单词搜索 II (Trie&dfs)

leetcode-79-单词搜索(用dfs解决)

洛谷P1019——单词接龙(DFS暴力搜索)

LeetCode79 单词搜索(dfs)

蓝桥杯 算法提高 单词接龙 _DFS_搜索 字符串比较