LeetCode讲解篇之79. 单词搜索

文章目录

题目描述

题解思路

我们遍历对矩阵中的每个点,对每个点采用深度优先搜索,检查是否能以当前点做为开头来匹配word

我们使用一个与矩阵相同规格的二维数组表示矩阵中对应的点是否被访问过,防止重复计算

题解代码

go 复制代码
func exist(board [][]byte, word string) bool {
    m, n := len(board), len(board[0])

	// 表示矩阵中i, j位置是否在一次搜索word的过程中被访问过
    used := make([][]bool, m)
    for i := 0; i < m; i++ {
        used[i] = make([]bool, n)
    }

	// 当前要匹配word哪一个字符的下标
    idx := 0

    var dfs func(i, j int) bool
    dfs = func(i, j int) bool {
    	// word所有字符已经找到
        if idx == len(word) {
            return true
        }
        // 越界、已经被访问过、当前矩阵中的字符不是word需要匹配的字符,这些情况表示从当前字符开始无法找到word[idx:]这个字符串
        if i < 0 || j < 0 || i >= m || j >= n || used[i][j] || board[i][j] != word[idx] {
            return false
        }

		// 继续搜索word[idx + 1:]
        idx++
        used[i][j] = true
        if dfs(i, j + 1) || dfs(i, j - 1) || dfs(i + 1, j) || dfs(i - 1, j) {
            return true
        }
        used[i][j] = false
        idx--

        return false
    }

    for i := 0; i < m; i++ {
        for j := 0; j < n; j++ {
            if dfs(i, j) {
                return true
            }
        }
    }

    return false
}

题目链接

https://leetcode.cn/problems/word-search/description/

相关推荐
小程故事多_802 小时前
[大模型面试系列] 深度解析ReAct框架,大模型Agent的“思考+行动”底层逻辑
人工智能·react.js·面试·职场和发展·智能体
YXXY3133 小时前
模拟算法的介绍
算法
happymaker06263 小时前
简单LRU的实现(基于LinkedHashMap)
算法·leetcode·lru
那我掉的头发算什么3 小时前
【面试八股】一篇文章讲清楚JVM面试常考
jvm·面试·职场和发展·java虚拟机
冬天vs不冷3 小时前
面试必知必会(13):MySQL锁机制
mysql·面试·职场和发展
华夏之光永存3 小时前
独家:国家级光刻机项目架构师面试对话实录
面试·职场和发展
KNeeg_3 小时前
黑马点评完整代码(RabbitMQ优化)+简历编写+面试重点 ⭐
java·redis·后端·spring·面试·职场和发展·黑马点评
FPGA小迷弟3 小时前
FPGA工程师常见面试问题,有参考答案,必学!!!
fpga开发·面试·职场和发展·verilog·fpga·modelsim
Java后端的Ai之路3 小时前
以为AI开发就是调接口?一场25K的面试让我看到真相,原来真正的技术深度在这!
人工智能·面试·职场和发展·agent·ai应用开发
会编程的土豆3 小时前
【数据结构与算法】空间复杂度从入门到面试:不仅会算,还要会解释
数据结构·c++·算法·面试·职场和发展