首页 > 编程语言 > 详细

回溯算法----单词搜索

时间:2020-04-02 10:23:25      阅读:59      评论:0      收藏:0      [点我收藏+]

给定一个二维网格和一个单词,找出该单词是否存在于网格中。

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

 

示例:

board =
[
  [‘A‘,‘B‘,‘C‘,‘E‘],
  [‘S‘,‘F‘,‘C‘,‘S‘],
  [‘A‘,‘D‘,‘E‘,‘E‘]
]

给定 word = "ABCCED", 返回 true
给定 word = "SEE", 返回 true
给定 word = "ABCB", 返回 false

提示:

  • board 和 word 中只包含大写和小写英文字母。
  • 1 <= board.length <= 200
  • 1 <= board[i].length <= 200
  • 1 <= word.length <= 10^3

解答(C++):
class Solution {
public:
    bool en;
    bool backTrace(vector<vector<char>>& board, int i, int j, string& word, int index) {
        if (board[i][j] != word[index]) 
            return false;
        if (index == word.size() -1)
            return true;
        
        char tmp = board[i][j];
        board[i][j] = 0;
        index++;
        if ( (i > 0 && backTrace(board, i-1, j, word, index)) //
           ||(j > 0 && backTrace(board, i, j-1, word, index)) //
           ||(i < board.size()-1 && backTrace(board, i+1, j, word, index)) //
           ||(j < board[0].size()-1 && backTrace(board, i, j+1, word, index)) //
           ) {
            return true;
        } 
        board[i][j] = tmp;    
        return false;   
    }
    
    bool exist(vector<vector<char>>& board, string word) {
         if (board.empty()) return false;
        
         for (int i = 0; i < board.size(); ++i) {
            for (int j = 0; j < board[0].size(); ++j) {
                if (backTrace(board, i, j, word, 0)) {
                    return true;
                }
            }    
         }
        
         return false;
            
    }
};

 



回溯算法----单词搜索

原文:https://www.cnblogs.com/vczf/p/12617655.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!