12. 矩阵中的路径(dfs)

题意:

请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径。路径可以从矩阵中的任意一格开始,每一步可以在矩阵中向左、右、上、下移动一格。如果一条路径经过了矩阵的某一格,那么该路径不能再次进入该格子。例如,在下面的3×4的矩阵中包含一条字符串“bfce”的路径(路径中的字母用加粗标出)。
但矩阵中不包含字符串“abfb”的路径,因为字符串的第一个字符b占据了矩阵中的第一行第二个格子之后,路径不能再次进入这个格子。

示例 1:

输入:board = [["A","B","D","E"],
              ["S","C","C","S"],  
              ["A","D","E","E"]], 
      word = "ABCCED"
输出:true

思路解析:

  1. 递归的参数:当前矩阵和其中的索引i和j,以及当前要匹配的字符串及索引k(第几个字符)
  2. 返回false的条件:i不能超出矩阵的索引范围;匹配字符不同
  3. 返回true的情况:当if(k==word.length-1) return true; //因为k是从0开始的,所以word.length必须减1,否则将会超出索引
  4. 将board[i][j]置为空字符是为了防止重复搜索
  5. 依次开启下上右左的递归模式,并记录结果返回
  6. 还原矩阵元素: 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));
    }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值