一起学习LeetCode热题100道(60/100)

60.单词搜索(学习)

给定一个 m x n 二维字符网格 board 和一个字符串单词 word 。如果 word 存在于网格中,返回 true ;否则,返回 false 。
单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中"相邻"单元格是那些水平相邻或垂直相邻的单元格。同一个单元格内的字母不允许被重复使用。

示例 1:

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

输出:true

示例 2:

输入:board = [["A","B","C","E"],["S","F","C","S"],["A","D","E","E"]], word = "SEE"

输出:true

示例 3:

输入:board = [["A","B","C","E"],["S","F","C","S"],["A","D","E","E"]], word = "ABCB"

输出:false

提示:

m == board.length

n = board[i].length

1 <= m, n <= 6

1 <= word.length <= 15

board 和 word 仅由大小写英文字母组成

解析:
一、边界条件和字符匹配检查:

1.如果当前位置超出网格边界、已被访问过、或当前单元格的字符与 word[index] 不匹配,则返回 false。

二、匹配完成检查:

1.如果 index 已经等于 word.length - 1(即已经匹配完整个 word),则返回 true。

三、标记当前位置为已访问:

1.将当前位置标记为已访问,以避免重复访问。

四、向四个方向搜索:

1.定义四个方向(上、下、左、右)的偏移量数组 directions。

2.遍历这四个方向,对每个方向执行 dfs 递归调用,传入新的行和列索引(通过当前索引加上方向的偏移量得到),以及 index + 1(因为已经匹配了一个字符)。

3.如果在任何一个方向的搜索中找到了匹配的路径(即 dfs 返回 true),则立即返回 true。

五、回溯:

1.如果所有方向的搜索都失败了(即没有找到匹配的路径),则需要回溯,即将当前位置重新标记为未访问,以便其他路径可以访问它。

2.注意:这里的回溯是通过在 dfs 函数返回前将 visited[row][col] 设置为 false 来实现的。

javascript 复制代码
var exist = function (board, word) {
    const rows = board.length;
    const cols = board[0].length;
    const visited = Array.from({ length: rows }, () => Array(cols).fill(false));

    // 辅助函数,用于进行深度优先搜索  
    function dfs(row, col, index) {
        // 检查边界条件和字符匹配  
        if (
            row < 0 ||
            row >= rows ||
            col < 0 ||
            col >= cols ||
            visited[row][col] ||
            board[row][col] !== word[index]
        ) {
            return false;
        }

        // 如果已经匹配完整个单词,则返回 true  
        if (index === word.length - 1) {
            return true;
        }

        // 标记当前位置为已访问  
        visited[row][col] = true;

        // 继续向四个方向搜索  
        const directions = [[-1, 0], [1, 0], [0, -1], [0, 1]];
        for (const [dx, dy] of directions) {
            if (dfs(row + dx, col + dy, index + 1)) {
                return true;
            }
        }

        // 回溯,重置当前位置为未访问  
        visited[row][col] = false;

        return false;
    }

    // 遍历二维网格的每个位置,作为搜索的起点  
    for (let i = 0; i < rows; i++) {
        for (let j = 0; j < cols; j++) {
            if (dfs(i, j, 0)) {
                return true;
            }
        }
    }

    return false;
};
相关推荐
圣保罗的大教堂17 分钟前
leetcode 61. 旋转链表 中等
leetcode
辰海Coding1 小时前
MiniSpring框架学习-整合 IoC 和 MVC(NPC)
学习·spring·mvc
全糖可乐气泡水2 小时前
Codex适配国产信创环境安装部署与技术适配全解析
开发语言·git·python·算法·百度
h_a_o777oah2 小时前
状态机+划分型 DP :深度解析K-划分问题下 DP 状态的转移逻辑(洛谷P2679 P2331 附C++代码)
c++·算法·动态规划·acm·状态机dp·划分型dp·滚动数组优化
05候补工程师2 小时前
从算法理想向工程现实的跨越:SLAM 核心架构、思维误区与 Nav2 实战避坑指南
人工智能·算法·安全·架构·机器人
知识分享小能手3 小时前
Flask入门学习教程,从入门到精通,数据库操作 — 知识点详解与案例代码(4)
数据库·学习·flask
手写码匠3 小时前
Android 17 适配实战指南:新特性解读、隐私变更与迁移全攻略
人工智能·深度学习·算法·aigc
珊瑚里的鱼4 小时前
leetcode42雨水
算法·leetcode
wubba lubba dub dub7504 小时前
第四十八周学习周报
学习
水木流年追梦4 小时前
大模型入门-大模型的推理策略
开发语言·python·算法·正则表达式·prompt