class Solution {
public boolean exist(char[][] board, String word) {
char []words = word.toCharArray();
for(int i=0;i<board.length;i++){
for(int j=0;j<board[0].length;j++){
if(dfs(board,words,i,j,0)) return true;
}
}
return false;
}
boolean dfs(char [][]board,char []word,int i,int j,int k){
if(i>=board.length||i<0||j>=board[0].length||j<0
||board[i][j]!=word[k]) return false;
if(k==word.length-1) return true;
char tmp=board[i][j];
board[i][j]='/';
boolean res=dfs(board,word,i+1,j,k+1)||dfs(board,word,i-1,j,k+1)
||dfs(board,word,i,j+1,k+1)||dfs(board,word,i,j-1,k+1);
board[i][j]=tmp;
return res;
}
}
典型的矩阵搜索问题,可使用 深度优先搜索(DFS)+ 剪枝 解决
技巧:递归搜索匹配字符串过程中,需要 board[i][j] = '/' 来防止 ”走回头路“ 。当匹配字符串不成功时,会回溯返回,此时需要board[i][j] = tmp 来”取消对此单元格的标记”。 在DFS过程中,每个单元格会多次被访问的, board[i][j] = '/'只是要保证在当前匹配方案中不要走回头路。