题目描述

请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径。路径可以从矩阵中的任意一个格子开始,每一步可以在矩阵中向左,向右,向上,向下移动一个格子。如果一条路径经过了矩阵中的某一个格子,则该路径不能再进入该格子。 例如 a b c e s f c s a d e e 矩阵中包含一条字符串"bcced"的路径,但是矩阵中不包含"abcb"路径,因为字符串的第一个字符b占据了矩阵中的第一行第二个格子之后,路径不能再次进入该格子。
 
题解:
  使用回溯法,进行深度遍历,并设置一个visit来标记时候遍历过
 
  

 class Solution {
public:
bool hasPath(char* matrix, int rows, int cols, char* str)
{
if (matrix == nullptr || rows < || cols < )return false;
if (str == nullptr)return true;
vector<bool>visit(rows*cols, false);
int pot = ;
for (int i = ; i < rows; ++i)
for (int j = ; j < cols; ++j)
if (DFS(matrix, rows, cols, i, j, visit, str, pot))
return true;
return false;
}
bool DFS(const char* matrix, const int rows, const int cols,int i, int j, vector<bool>&visit,const char *str, int &pot)
{
if (str[pot] == '\0')return true;
bool flag = false;
if (i >= && i < rows && j >= && j < cols &&
matrix[i*cols + j] == str[pot] && visit[i*cols + j] == false)
{
++pot;
visit[i*cols + j] = true;
flag = DFS(matrix, rows, cols, i + , j, visit, str, pot) ||
DFS(matrix, rows, cols, i - , j, visit, str, pot) ||
DFS(matrix, rows, cols, i, j + , visit, str, pot) ||
DFS(matrix, rows, cols, i, j - , visit, str, pot);
if (flag == false)
{
--pot;
visit[i*cols + j] = false;//回溯
}
}
return flag;
}
};

最新文章

  1. Android-Activity使用(2) -传值
  2. IOS 推送原理
  3. ArcGis API FOR Silverlight 做了个导航工具~
  4. IIS Express添加MIME映射
  5. Help Jimmy ~poj-1661 基础DP
  6. Hibernate与Mybatis的比较
  7. 北京大学Cousera学习笔记--4-计算导论与C语言基础--计算机的基本原理-程序运行的基本原理
  8. APP测试常见点
  9. Custom Default Node Colors and Shapes in Houdini 16.5
  10. 【转】Python数据类型之“文本序列(Text Sequence)”
  11. mac docker环境搭建mysql主从同步服务器
  12. wire [7:0] regAddr; 理解
  13. 自学huawei之路-AC6005版本升级步骤
  14. linux内核中的DMI是什么?
  15. bzoj千题计划190:bzoj4300: 绝世好题
  16. js - 预加载+监听图片资源加载制作进度条
  17. map用法小例子
  18. C++11 之for 新解 auto
  19. List排序方法
  20. react实现页面切换动画效果

热门文章

  1. FastJson乱序问题
  2. Invoking destroy method &#39;close&#39; on bean with name &#39;dataSource&#39;
  3. Awesome Adb——一份超全超详细的 ADB 用法大全
  4. Android逆向之smali语法宝典
  5. XML 介绍
  6. 1. Python版本的选择与安装
  7. HTML —— 表格
  8. JAVA求回文数
  9. ajax实现异步刷新
  10. Python面试题之阅读下面的代码,写出A0,A1至An的最终值