剑指Offer12:矩阵中的路径(Java)

本文探讨了一种在二维数组中搜索特定单词的算法,重点介绍了回溯法的应用。通过使用递归和边界检查,文章详细解释了如何从任意起始位置遍历矩阵,寻找与给定单词匹配的路径。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述:
在这里插入图片描述

解法思路:
    这次没能做出来,又去看了题解,发现果然还是要多多练习。
    看了这次的题目,让我最难解决的是不确定性。不确定从哪个元素开始,不确定是它是向左还是向右,向上还是向下,有些地方还有限制,只有一个或者两个方向可以走。题解使用的是回溯法,这的确是一个很好的办法。使用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;
}
}

执行结果:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值