给定一个二维面板和一个单词,找出该单词是否存在于网格中。
这个词可由顺序相邻的单元格内的字母构成,其中“相邻”单元格是那些水平相邻或垂直相邻的单元格。同一个单元格内的字母不允许被重复使用。
public static boolean exist(char[][] board, String word) {
char[] strs = word.toCharArray();
int r = board.length;
int c = board[0].length;
for(int i = 0; i < r; i ++){
for(int j = 0; j < c; j ++){
//二维数组中匹配word中的第一个单词
if(board[i][j] == strs[0] && wordsExist(board, 0, i, j, strs)){
return true;
}
}
}
return false;
}
public static boolean wordsExist(char[][] board, int index, int r, int c, char[] strs){
//如果是word最后一个单词,则遍历完成,结束
if(index == strs.length - 1){
return true;
}
char str = strs[index + 1];//开始查找的单词
char temp = board[r][c];//保存二维数组开始查找的位置的单词
board[r][c] = ' ';//标志为找过的位置
//上
if(r - 1 >= 0 && board[r - 1][c] == str && wordsExist(board, index + 1, r - 1, c, strs)){
return true;
}
//下
if(r + 1 < board.length && board[r + 1][c] == str && wordsExist(board, index + 1, r + 1, c, strs)){
return true;
}
//左
if(c - 1 >= 0 && board[r][c - 1] == str && wordsExist(board, index + 1, r, c - 1, strs)){
return true;
}
//右
if(c + 1 < board[0].length && board[r][c + 1] == str && wordsExist(board, index + 1, r, c + 1, strs)){
return true;
}
board[r][c] = temp;//还原原来的单词
return false;
}