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

你可能感兴趣的文章
mysql 协议的退出命令包及解析
查看>>
mysql 取表中分组之后最新一条数据 分组最新数据 分组取最新数据 分组数据 获取每个分类的最新数据
查看>>
mysql 多个表关联查询查询时间长的问题
查看>>
mysql 多字段删除重复数据,保留最小id数据
查看>>
MySQL 多表联合查询:UNION 和 JOIN 分析
查看>>
MySQL 大数据量快速插入方法和语句优化
查看>>
mysql 如何给SQL添加索引
查看>>
mysql 字段区分大小写
查看>>
mysql 字段合并问题(group_concat)
查看>>
mysql 字段类型类型
查看>>
MySQL 字符串截取函数,字段截取,字符串截取
查看>>
MySQL 存储引擎
查看>>
mysql 存储过程 注入_mysql 视图 事务 存储过程 SQL注入
查看>>
MySQL 存储过程参数:in、out、inout
查看>>
mysql 存储过程每隔一段时间执行一次
查看>>
mysql 存在update不存在insert
查看>>
Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
查看>>
Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
查看>>
Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
查看>>
Mysql 学习总结(89)—— Mysql 库表容量统计
查看>>