题目描述:
解法思路:
这次没能做出来,又去看了题解,发现果然还是要多多练习。
看了这次的题目,让我最难解决的是不确定性。不确定从哪个元素开始,不确定是它是向左还是向右,向上还是向下,有些地方还有限制,只有一个或者两个方向可以走。题解使用的是回溯法,这的确是一个很好的办法。使用index变量确定到第几个字符串元素,使用for循环来遍历二维数组每个元素作为起点,然后设置不符合题目要求的条件,要么超出边界(就是行大于二维数组最大行数或者小于0,列大于二维数组最大列数或者小于0),要么该元素和字符串的index位元素不符合。当index等于字符串长度-1时,证明之前的元素都符合题目条件,此时字符串的元素在二维数组中已经有一条路径了,返回true即可。然后我们使用一个变量保存当前的二维数组的元素值,然后修改当前的二维数组的元素值,为的是防止重新走回原来的元素。然后通过递归的方法判断四个方向即可。
代码实现:
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++) {
//从[i,j]这个坐标开始查找
if (dfs(board, words, i, j, 0))
return true;
}
}
return false;
}
boolean dfs(char[][] board, char[] word, int i, int j, int index) {
//边界的判断,如果越界直接返回false。index表示的是查找到字符串word的第几个字符,
//如果这个字符不等于board[i][j],说明验证这个坐标路径是走不通的,直接返回false
if (i >= board.length || i < 0 || j >= board[0].length || j < 0 || board[i][j] != word[index])
return false;
//如果word的每个字符都查找完了,直接返回true
if (index == word.length - 1)
return true;
//把当前坐标的值保存下来,为了在最后复原
char tmp = board[i][j];
//然后修改当前坐标的值
board[i][j] = '.';
//走递归,沿着当前坐标的上下左右4个方向查找
boolean res = dfs(board, word, i + 1, j, index + 1) || dfs(board, word, i - 1, j, index + 1) ||
dfs(board, word, i, j + 1, index + 1) || dfs(board, word, i, j - 1, index + 1);
//递归之后再把当前的坐标复原
board[i][j] = tmp;
return res;
}
}
执行结果: