题目描述:

给定一个二维网格和一个单词,找出该单词是否存在于网格中。

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

示例:

board =
[
['A','B','C','E'],
['S','F','C','S'],
['A','D','E','E']
] 给定 word = "ABCCED", 返回 true.
给定 word = "SEE", 返回 true.
给定 word = "ABCB", 返回 false.

要完成的函数:

bool exist(vector<vector<char>>& board, string word)

说明:

1、这道题给定一个二维的vector,里面存放着多个英文字符,还给了一个string,代表一个英文单词。

要求判断二维vector中存不存在一条路径,连起来刚好就是string代表的单词。

这条路径不能使用重复的字符。

如果存在这样一条路径,那么返回true,不存在就返回false。

2、这道题其实也就是深度优先搜索(DFS)的题目,熟悉这个算法的同学做这道题会很快。

我们还是照旧,举个例子,大致说明一下思路。

board =
[
['A','B','C','E'],
['S','F','C','S'],
['A','D','E','E']
]

给定的单词是SEE,那么我们首先在矩阵中找到S,有两个,我们先试第一个,明显第二个字母就对不上了,于是我们进入对第二个的查找。

在第二个周围,我们先试S上方的E,然后再在这个E的周围找另一个E,明显没有。

于是我们退一步,不试S上方的E了,我们尝试S下方的E,可以,再在其附近找另一个E,也找得到。

我们在尝试的时候,要注意这个字符之前有没有使用过,这一步要做点处理。

从上述思路中,我们可以知道要用循环+递归的方法来做这道题。

先用循环找到第一个字符的索引,然后进入递归,如果递归成功找到了,那么返回true。

如果不存在,那么再循环找第一个字符的下一个索引,然后同样进入递归,如果递归成功了,那么返回true。

如果还是没有,那么再循环,一直循环,如果一直不满足,最后返回false。

代码如下(附详解):

    bool dfs(vector<vector<char>>& board,int i,int j,string word,int index)
{
if(index==word.size())return true;//退出条件,满足了说明成功找到
int hang=board.size(),lie=board[0].size();
if(i>0)//尝试上方的字符
{
if(board[i-1][j]==word[index])
{
board[i-1][j]='!';//修改,避免重复使用
if(dfs(board,i-1,j,word,index+1))//再度进入递归
return true;
board[i-1][j]=word[index];//修改回去
}
}
if(i<hang-1)//尝试下方的字符
{
if(board[i+1][j]==word[index])
{
board[i+1][j]='!';
if(dfs(board,i+1,j,word,index+1))
return true;
board[i+1][j]=word[index];
}
}
if(j>0)//尝试左边的字符
{
if(board[i][j-1]==word[index])
{
board[i][j-1]='!';
if(dfs(board,i,j-1,word,index+1))
return true;
board[i][j-1]=word[index];
}
}
if(j<lie-1)//尝试右边的字符
{
if(board[i][j+1]==word[index])
{
board[i][j+1]='!';
if(dfs(board,i,j+1,word,index+1))
return true;
board[i][j+1]=word[index];
}
}
return false;//如果尝试四个方向都没能找到,返回false
}
bool exist(vector<vector<char>>& board, string word)
{
int hang=board.size(),lie=board[0].size();
for(int i=0;i<hang;i++)
{
for(int j=0;j<lie;j++)
{
if(board[i][j]==word[0])//找到第一个字符的索引
{
board[i][j]='!';//修改board中这个索引的值,避免重复使用
if(dfs(board,i,j,word,1))//进入递归,如果返回true,那么找得到,最终返回true
return true;
board[i][j]=word[0];//如果递归没成功找到,那么把索引对应的字符给修改回去
}
}
}
return false;//一直没能成功,说明不存在这样一条路径,返回false
}

上述代码实测20ms,beats 94.50% of cpp submissions。

leetcode-79-单词搜索(用dfs解决)的更多相关文章

  1. Java实现 LeetCode 79 单词搜索

    79. 单词搜索 给定一个二维网格和一个单词,找出该单词是否存在于网格中. 单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中"相邻"单元格是那些水平相邻或垂直相邻的单元格. ...

  2. Leetcode 79.单词搜索

    单词搜索 给定一个二维网格和一个单词,找出该单词是否存在于网格中. 单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中"相邻"单元格是那些水平相邻或垂直相邻的单元格.同一个单 ...

  3. [LeetCode] 79. 单词搜索(DFS,回溯)

    题目 给定一个二维网格和一个单词,找出该单词是否存在于网格中. 单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中"相邻"单元格是那些水平相邻或垂直相邻的单元格.同一个单元格 ...

  4. LeetCode——79. 单词搜索

    给定一个二维网格和一个单词,找出该单词是否存在于网格中. 单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中"相邻"单元格是那些水平相邻或垂直相邻的单元格.同一个单元格内的字 ...

  5. LeetCode 79.单词搜索 - JavaScript

    题目描述:给定一个二维网格和一个单词,找出该单词是否存在于网格中. 单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中"相邻"单元格是那些水平相邻或垂直相邻的单元格.同一个单 ...

  6. LeetCode 79. 单词搜索(Word Search)

    题目描述 给定一个二维网格和一个单词,找出该单词是否存在于网格中. 单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中“相邻”单元格是那些水平相邻或垂直相邻的单元格.同一个单元格内的字母不允许被 ...

  7. Leetcode之回溯法专题-79. 单词搜索(Word Search)

    Leetcode之回溯法专题-79. 单词搜索(Word Search) 给定一个二维网格和一个单词,找出该单词是否存在于网格中. 单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中“相邻”单元 ...

  8. [LeetCode题解]79. 单词搜索

    题目描述 题目:79. 单词搜索 解题思路 遍历 首先找重复性,题目说给定单词是否存在于二维数组中,可以简化为从 (x, y) 走 n 步(n 表示单词长度),查看给定单词是否存在.然后再遍历二维数组 ...

  9. [leetcode] 212. 单词搜索 II(Java)

    212. 单词搜索 II 这leetcode的评判机绝对有问题!!同样的代码提交,有时却超时!害得我至少浪费两个小时来寻找更优的答案= =,其实第一次写完的代码就可以过了,靠!!!第207位做出来的 ...

  10. Leetcode之深度优先搜索(DFS)专题-494. 目标和(Target Sum)

    Leetcode之深度优先搜索(DFS)专题-494. 目标和(Target Sum) 深度优先搜索的解题详细介绍,点击 给定一个非负整数数组,a1, a2, ..., an, 和一个目标数,S.现在 ...

随机推荐

  1. 综合:bool类型 命名空间 输入输出

    ----------siwuxie095                 题目要求: 使用一个函数找出一个整型数组中的最大值或最小值         注意: 1.直接书写 cin cout endl, ...

  2. 自定义对象实现copy,遵守协议<NSCopying, NSMutableCopying>

    自定义对象实现copy,步骤 1.需要遵守NSCopying协议 2.实现协议中的- (id)copyWithZone:(NSZone *)zone 3.在- (id)copyWithZone:(NS ...

  3. WebLogic(12C)——几个基本概念

    转http://blog.csdn.net/hanxuemin12345/article/details/46287597 目录(?)[-] 域Domain 服务器Server 机器Machine W ...

  4. C语言日志处理

    一.简介 zlog是一个高可靠性.高性能.线程安全.灵活.概念清晰的纯C日志函数库,在效率.功能.安全性上大大超过了log4c,并且是用c写成的,具有比较好的通用性. 二.安装 下载 https:// ...

  5. Java Thread系列(七)死锁

    Java Thread系列(七)死锁 当线程需要同时持有多个锁时,有可能产生死锁.考虑如下情形: 线程 A 当前持有互斥所锁 lock1,线程 B 当前持有互斥锁 lock2.接下来,当线程 A 仍然 ...

  6. HDU1879 继续畅通工程 2017-04-12 19:12 50人阅读 评论(0) 收藏

    继续畅通工程 Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) Total Submis ...

  7. jsp中路径的写法

    在JavaWeb开发中,常使用绝对路径的方式来引入JavaScript和CSS文件,这样可以避免因为目录变动导致引入文件找不到的情况 代码” ${pageContext.request.context ...

  8. SOCK开发之---TCP/IP简介

    在开发通信程序之前,都要先确定这些程序相互通信所使用的协议(protocol),在深入设计前,我们都需要先从高层次来判断通信由哪个程序发起以及相应在何时产生. 举例来说,一般认为web服务器是一个长时 ...

  9. Lucene教程(四) 索引的更新和删除

    这篇文章是基于上一篇文章来写的,使用的是IndexUtil类,下面的例子不在贴出整个类的内容,只贴出具体的方法内容. 3.5版本: 先写了一个check()方法来查看索引文件的变化:   /**   ...

  10. Lucene索引的【增、删、改、查】

    前言 搞检索的,应该多少都会了解Lucene一些,它开源而且简单上手,官方API足够编写些小DEMO.并且根据倒排索引,实现快速检索.本文就简单的实现增量添加索引,删除索引,通过关键字查询,以及更新索 ...