79. [✔][M]单词搜索
给定一个 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仅由大小写英文字母组成
进阶: 你可以使用搜索剪枝的技术来优化解决方案,使其在 board 更大的情况下可以更快解决问题?
题解:
// @lc code=start
function exist(board: string[][], word: string): boolean {
    let m = board.length;
    let n = board[0].length;
    let res = false;
    const dfs = (board: string[][], i: number, j: number, word: string, pos: number) => {
        if (pos === word.length) {
            res = true;
            return;
        }
        // 已经找到了一个答案,不用再搜索了
        if (res) {
            return;
        }
        if (i < 0 || j < 0 || i >= m || j >= n) {//越界
            return;
        }
        if (board[i][j] !== word[pos]) {
            return;
        }
        board[i][j] = '-' + board[i][j];//添加-号
        dfs(board, i, j - 1, word, pos + 1);//上
        dfs(board, i, j + 1, word, pos + 1);//下
        dfs(board, i - 1, j, word, pos + 1);//左
        dfs(board, i + 1, j, word, pos + 1);//右
        board[i][j] = board[i][j].replace("-", "");//移除-号
    }
    for (let i = 0; i < m; i++) {
        for (let j = 0; j < n; j++) {
            dfs(board, i, j, word, 0);
            if (res) {
                return true;
            }
        }
    }
    return false;
};
// @lc code=end