LeetCode Hot100 79.单词搜索

题目

给定一个 m x n 二维字符网格 board 和一个字符串单词 word 。如果 word 存在于网格中,返回 true ;否则,返回 false 。

单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中“相邻”单元格是那些水平相邻或垂直相邻的单元格。同一个单元格内的字母不允许被重复使用。

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++) {
                if (dfs(board, words, i, j, 0)) return true;
            }
        }
        return false;
    }
    boolean dfs(char[][] board, char[] word, int i, int j, int k) {
        if (i >= board.length || i < 0 || j >= board[0].length || j < 0 || board[i][j] != word[k]) return false;
        if (k == word.length - 1) return true;
        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;
    }
}

相关推荐

  1. 【回溯】79. 单词搜索

    2023-12-20 19:40:03       49 阅读
  2. leetCode79. 单词搜索

    2023-12-20 19:40:03       30 阅读
  3. LeetCodehot100

    2023-12-20 19:40:03       57 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-20 19:40:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-20 19:40:03       100 阅读
  3. 在Django里面运行非项目文件

    2023-12-20 19:40:03       82 阅读
  4. Python语言-面向对象

    2023-12-20 19:40:03       91 阅读

热门阅读

  1. docker查看日志

    2023-12-20 19:40:03       63 阅读
  2. docker nginx 部署静态网站

    2023-12-20 19:40:03       58 阅读
  3. TongRDS2.2 Center 哨兵配置

    2023-12-20 19:40:03       55 阅读
  4. 关于C语言提高的一些总结

    2023-12-20 19:40:03       55 阅读
  5. vi和vim的区别

    2023-12-20 19:40:03       65 阅读
  6. css 2D转换

    2023-12-20 19:40:03       61 阅读
  7. 15.动态规划:数据结构优化DP

    2023-12-20 19:40:03       64 阅读
  8. k8s pod网络排查教程

    2023-12-20 19:40:03       57 阅读
  9. docker 搭建靶场

    2023-12-20 19:40:03       59 阅读