博客
关于我
leetCode 79 单词搜索 (dfs,回溯)
阅读量:271 次
发布时间:2019-03-01

本文共 1292 字,大约阅读时间需要 4 分钟。

题目链接:

题目描述:

给定一个字母矩阵,所有的字母都与上下左右四个方向上的字母相连。给定一个字符串,求字符串能不能在字母矩阵中寻找到。
 
输入输出:
 

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
>& board, string word) { if(board.empty()) return false; int m=board.size(),n=board[0].size(); vector
>visited(m,vector
(n,false)); bool find=false; for(int i=0;i
>&board,string &word,bool &find,vector
>&visited,int pos){ if(i<0||i>=board.size()||j<0||j>=board[0].size())//基本筛选条件判断是否越界 { return ; } if(visited[i][j]||find||board[i][j]!=word[pos])//如果没访问过当前节点,且没找字符串,且当前字符等于word中某一字符,代码才向下进行,才能继续搜索 { return ; } if(pos==word.size()-1)//如果层级已经达到所要找的word字符串长度 则终止搜索 { find=true;//上几步代码已经进行了条件筛选 如果进入此if预计中find一定为true return ; } visited[i][j]=true;// 修改当前节点状态 backtracking(i+1,j,board,word,find,visited,pos+1); backtracking(i-1,j,board,word,find,visited,pos+1); backtracking(i,j+1,board,word,find,visited,pos+1); backtracking(i,j-1,board,word,find,visited,pos+1); visited[i][j]=false;// 回改当前节点状态 }

 

转载地址:http://uxlx.baihongyu.com/

你可能感兴趣的文章
Mstsc 远程桌面链接 And 网络映射
查看>>
Myeclipse常用快捷键
查看>>
MyEclipse用(JDBC)连接SQL出现的问题~
查看>>
myeclipse的新建severlet不见解决方法
查看>>
MyEclipse设置当前行背景颜色、选中单词前景色、背景色
查看>>
MyEclipse配置SVN
查看>>
MTCNN 人脸检测
查看>>
MyEcplise中SpringBoot怎样定制启动banner?
查看>>
MyPython
查看>>
MTD技术介绍
查看>>
MySQL
查看>>
mysql
查看>>
MTK Android 如何获取系统权限
查看>>
MySQL - 4种基本索引、聚簇索引和非聚索引、索引失效情况、SQL 优化
查看>>
MySQL - ERROR 1406
查看>>
mysql - 视图
查看>>
MySQL - 解读MySQL事务与锁机制
查看>>
mysql 1264_关于mysql 出现 1264 Out of range value for column 错误的解决办法
查看>>
mysql 1593_Linux高可用(HA)之MySQL主从复制中出现1593错误码的低级错误
查看>>
mysql ansi nulls_SET ANSI_NULLS ON SET QUOTED_IDENTIFIER ON 什么意思
查看>>