博客
关于我
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/

你可能感兴趣的文章
mysqli
查看>>
MySQLIntegrityConstraintViolationException异常处理
查看>>
mysqlreport分析工具详解
查看>>
MySQLSyntaxErrorException: Unknown error 1146和SQLSyntaxErrorException: Unknown error 1146
查看>>
Mysql_Postgresql中_geometry数据操作_st_astext_GeomFromEWKT函数_在java中转换geometry的16进制数据---PostgreSQL工作笔记007
查看>>
mysql_real_connect 参数注意
查看>>
mysql_secure_installation初始化数据库报Access denied
查看>>
MySQL_西安11月销售昨日未上架的产品_20161212
查看>>
Mysql——深入浅出InnoDB底层原理
查看>>
MySQL“被动”性能优化汇总
查看>>
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>
Mysql下载以及安装(新手入门,超详细)
查看>>
MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
查看>>