题意:
请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径。路径可以从矩阵中的任意一格开始,每一步可以在矩阵中向左、右、上、下移动一格。如果一条路径经过了矩阵的某一格,那么该路径不能再次进入该格子。例如,在下面的3×4的矩阵中包含一条字符串“bfce”的路径(路径中的字母用加粗标出)。
但矩阵中不包含字符串“abfb”的路径,因为字符串的第一个字符b占据了矩阵中的第一行第二个格子之后,路径不能再次进入这个格子。
示例 1:
输入:board = [["A","B","D","E"],
["S","C","C","S"],
["A","D","E","E"]],
word = "ABCCED"
输出:true
思路解析:
- 递归的参数:当前矩阵和其中的索引i和j,以及当前要匹配的字符串及索引k(第几个字符)
- 返回false的条件:i不能超出矩阵的索引范围;匹配字符不同
- 返回true的情况:当if(k==word.length-1) return true; //因为k是从0开始的,所以word.length必须减1,否则将会超出索引
- 将board[i][j]置为空字符是为了防止重复搜索
- 依次开启下上右左的递归模式,并记录结果返回
- 还原矩阵元素: board[i][j]=word[k]; //回溯时将寻找到的字符放入对应的位置中,还原至初始值,防止匹配失败回溯时出现类似贪吃蛇咬尾巴的情况
package leecode;
/**
* 功能描述:矩阵中的路径
*
* @Author: lwg
* @Date: 2021/4/7 0:50
*/
public class demo12 {
public static 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)){ //调用是i,j可以依次遍历往下找
return true;
}
}
}
return false;
}
public static boolean dfs(char[][] board, char[] word, int i, int j, int k){
if(i<0||i>=board.length||j<0||j>=board[0].length||board[i][j]!=word[k]){
return false;
}
if(k==word.length-1) return true; //因为k是从0开始的,所以word.length必须减1,否则将会超出索引
board[i][j]='\0'; //防止走过的再走一遍(下上右左,此时找到了此位置的字符,当在下一个字符判断时,不用再次走一步)
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]=word[k]; //回溯时将寻找到的字符放入对应的位置中,还原至初始值,防止匹配失败回溯时出现类似贪吃蛇咬尾巴的情况
return res;
}
public static void main(String[] args) {
char[][] board= {{'A','B','D','E'},
{'S','C','C','S'},
{'A','D','E','E'}};
String word="ABCCED";
System.out.println(exist(board, word));
}
}