79. 单词搜索

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

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

示例:

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

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

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/word-search
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

 1 public class Solution {
 2     private boolean[][] flag = null;
 3     private char[] words = null;
 4     private int row = 0;
 5     private int col = 0;
 6 
 7     // i,j是word[0]的位置; cur表示words中的位置
 8     private boolean helper(char[][] board, int cur, int i, int j) {
 9         if (cur == words.length)
10             return true;
11         //
12         if (i-1 >= 0 && !flag[i-1][j] && board[i-1][j] == words[cur]) {
13             flag[i-1][j] = true;
14             if (helper(board, cur+1, i-1,j))
15                 return true;
16             flag[i-1][j] = false;
17         }
18         //
19         if (i+1 < row && !flag[i+1][j] && board[i+1][j] == words[cur]) {
20             flag[i+1][j] = true;
21             if (helper(board, cur+1, i+1, j))
22                 return true;
23             flag[i+1][j] = false;
24         }
25         //
26         if (j-1 >= 0 && !flag[i][j-1] && board[i][j-1] == words[cur]) {
27             flag[i][j-1] = true;
28             if (helper(board, cur+1, i, j-1))
29                 return true;
30             flag[i][j-1] = false;
31         }
32         //
33         if (j+1 < col && !flag[i][j+1] && board[i][j+1] == words[cur]) {
34             flag[i][j+1] = true;
35             if (helper(board, cur+1, i, j+1))
36                 return true;
37             flag[i][j+1] = false;
38         }
39         return false;
40     }
41 
42     public boolean exist(char[][] board, String word) {
43         words = word.toCharArray();
44         flag = new boolean[board.length][board[0].length];
45         row = board.length;
46         col = board[0].length;
47         for (int i = 0; i < row; i++) {
48             for (int j = 0; j < col; j++) {
49                 if (board[i][j] == words[0]) {
50                     flag[i][j] = true;
51                     if (helper(board, 1, i, j))
52                         return true;
53                     flag[i][j] = false;
54                 }
55             }
56         }
57         return false;
58     }
59 
60     public static void main(String[] args) {
61         char[][] board = {
62                 {'A','B','C','E'},
63                 {'S','F','C','S'},
64                 {'A','D','E','E'}
65         };
66         boolean abcced = new Solution().exist(board, "SEE");
67         System.out.println("abcced = " + abcced);
68     }
69 }

 

posted @ 2019-10-01 19:47  赤云封天  阅读(126)  评论(0编辑  收藏  举报