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

你可能感兴趣的文章
MyEcplise中SpringBoot怎样定制启动banner?
查看>>
MyPython
查看>>
MTD技术介绍
查看>>
MySQL
查看>>
MySQL
查看>>
mysql
查看>>
MTK Android 如何获取系统权限
查看>>
MySQL - 4种基本索引、聚簇索引和非聚索引、索引失效情况、SQL 优化
查看>>
MySQL - ERROR 1406
查看>>
mysql - 视图
查看>>
MySQL - 解读MySQL事务与锁机制
查看>>
MTTR、MTBF、MTTF的大白话理解
查看>>
mt_rand
查看>>
mysql -存储过程
查看>>
mysql /*! 50100 ... */ 条件编译
查看>>
mudbox卸载/完美解决安装失败/如何彻底卸载清除干净mudbox各种残留注册表和文件的方法...
查看>>
mysql 1264_关于mysql 出现 1264 Out of range value for column 错误的解决办法
查看>>
mysql 1593_Linux高可用(HA)之MySQL主从复制中出现1593错误码的低级错误
查看>>
mysql 5.6 修改端口_mysql5.6.24怎么修改端口号
查看>>
MySQL 8.0 恢复孤立文件每表ibd文件
查看>>