leetcode-79单词搜索(深搜dfs)[通俗易懂]

leetcode-79单词搜索(深搜dfs)[通俗易懂]给定一个 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:输

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

给定一个 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. 深搜dfs
class Solution { 
   
public:
    typedef pair<int,int>PII;
    int dx[4] = { 
   0,1,0,-1},dy[4] = { 
   -1,0,1,0};
    bool dfs(PII p,int u,int len,vector<vector<char>> &board,string &word,vector<vector<bool> >&vis){ 
   
        if(u == len)return true;
        int x = p.first,y = p.second;
        if(x < 0 || x >= board.size() || y < 0 || y >= board[0].size())return false;
        if(vis[x][y])return false;
        vis[x][y] = true;
        if(board[p.first][p.second] == word[u]){ 
   
            for(int k = 0;k < 4;k ++){ 
   
                int a = p.first + dx[k],b = p.second + dy[k];
                if(dfs({ 
   a,b},u + 1,len,board,word,vis))return true;
            }
        }
        vis[p.first][p.second] = false;
        return false;
    }
    bool exist(vector<vector<char>>& board, string word) { 
   
        int n = board.size(),m = board[0].size();
        vector<vector<bool> >vis(n,vector<bool>(m,false));
        for(int i = 0;i < n;i ++){ 
   
            for(int j = 0;j < m;j ++){ 
   
                if(dfs({ 
   i,j},0,word.size(),board,word,vis))return true;
            }
        }
        return false;
    }
};
  1. 宽搜bfs
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/169156.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月9日 下午9:16
下一篇 2022年8月9日 下午9:36


相关推荐

  • java(3)-深入理解java异常处理机制

    java(3)-深入理解java异常处理机制1.引子try…catch…finally恐怕是大家再熟悉不过的语句了,而且感觉用起来也是很简单,逻辑上似乎也是很容易理解。不过,我亲自体验的“教训”告诉我,这个东西可不是想象中的那么简单、听话。不信?那你看看下面的代码,“猜猜”它执行后的结果会是什么?不要往后看答案、也不许执行代码看真正答案哦。如果你的答案是正确,那么这篇文章你就不用浪费时间看啦。pa

    2022年5月12日
    35
  • Vim下多行同时编辑与删除技巧

    Vim下多行同时编辑与删除技巧问题 在 Vim 内同时对多行增加或删除相同的内容 如 item1item2it 变成 增加 my item1my item2my item3 再变成 删除 tem1tem2tem3 方法 编辑 1 将光标移到要插入相同内容的第一行第一个字符上 如上面代码中 item1 中的 i 上按下 ctrl v 进入 visualblock 模式 2 按两次 j 或者 2j 将光标移动到要插入的最后一样 如上面代码中 item3 中的 i 上按下 I 大写 i 进入编辑

    2025年10月24日
    9
  • linux 命令chmod 755的意思[通俗易懂]

    linux 命令chmod 755的意思[通俗易懂]chmod是Linux下设置文件权限的命令,后面的数字表示不同用户或用户组的权限。 一般是三个数字:第一个数字表示文件所有者的权限第二个数字表示与文件所有者同属一个用户组的其他用户的权限第三个数字表示其它用户组的权限。      权限分为三种:读(r=4),写(w=2),执行(x=1)。综合起来还有可读可执行(rx=5=4+1)、可读可写(rw=6=4+2)、可读可写可执行(…

    2022年7月16日
    35
  • XAML属性

    XAML属性一 属性的设置方法属性 属性是对 XAML 元素特征进行描述的方法 属性不允许在 XAML 中重复设置多次 允许在托管代码中改变元素的属性值设置几种方式 1 属性语法 2 属性元素语法 3 内容元素语法 4 集合语法 1 属性语法每个属性对应一个属性值 属性值类型必须与属性匹配一个标记中可以设置的多个属性例子

    2026年3月16日
    2
  • MacBook pycharm添加模块

    MacBook pycharm添加模块MacBookpycha 添加模块一 找到 pycharm 右下角对现有版本信息的描述 CurrentInter 二 选中并打开 InterpreterS 三 选中并打开 pip 四 在上方搜索栏搜索模块五 点击下方 InstallPacka

    2026年3月18日
    1
  • Exception-NoSuchMethodException

    Exception-NoSuchMethodExceptionNoSuchMethodException-无法找到某一特定方法时,抛出该异常所遇到过的NoSuchMethodException情况:在使用反射时使用如下代码: //创建构造器对象,该方法只能获取public构造,否则会抛出NoSuchMethodException异常 Constructorconstructor=cls.getConstructo

    2022年6月22日
    42

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号