题目:

* 请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径。
* 路径可以从矩阵中的任意一个格子开始,每一步可以在矩阵中向左,向右,向上,向下移动一个格子。
* 如果一条路径经过了矩阵中的某一个格子,则之后不能再次进入这个格子。
* 例如
* a b c e
* s f c s
* a d e e
* 这样的3 X 4 矩阵中包含一条字符串"bcced"的路径,但是矩阵中不包含"abcb"路径,
* 因为字符串的第一个字符b占据了矩阵中的第一行第二个格子之后,路径不能再次进入该格子。

先上答案:暂时没有理解怎么使用回溯法解决。只是知道使用一个辅助数组来记录走过的路径。后续再返回来看,并试试循环。

 public boolean hasPath(char[] matrix, int rows, int cols, char[] str) {
if (matrix == null || rows < 1 || cols < 1 || str == null) {
return false;
}
boolean[] visited = new boolean[rows * cols];
int pathLength = 0;
for (int row = 0; row < rows; row++) {
for (int col = 0; col < cols; col++) {
if (hasPathCore(matrix, rows, cols, row, col, str, pathLength, visited)) {
return true;
}
}
}
return false;
} private boolean hasPathCore(char[] matrix, int rows, int cols, int row, int col, char[] str, int pathLength, boolean[] visited) {
if (pathLength == str.length) {
return true;
}
boolean hasPath = false;
if (row >= 0 && row < rows && col >= 0 && col < cols
&& matrix[row * cols + col] == str[pathLength]
&& !visited[row * cols + col]) {
pathLength++;
visited[row * cols + col] = true;
hasPath = hasPathCore(matrix, rows, cols, row, col - 1, str, pathLength, visited)
|| hasPathCore(matrix, rows, cols, row, col + 1, str, pathLength, visited)
|| hasPathCore(matrix, rows, cols, row - 1, col, str, pathLength, visited)
|| hasPathCore(matrix, rows, cols, row + 1, col, str, pathLength, visited);
if (!hasPath) {
pathLength--;
visited[row * cols + col] = false;
}
}
return hasPath;
}

最新文章

  1. scrapy 和 scrapy_redis 安装
  2. Android下如何计算两经纬点之间距离
  3. mybaties中在xml中map添加一个list中的判断
  4. ubuntu 修改ssh远程主机名称,mac开机运行命令,静默方式启动virtual box虚拟机,静默执行run脚本
  5. 初始化css代码需要注意的
  6. Xcode7连接网络设置
  7. IOS开发系列 --- 核心动画
  8. Android中ListView无法点击
  9. 一个简单的Spring AOP例子
  10. 菜鸟从零学编程(七)——搭建一个完整的Java开发环境
  11. Makefile分析基础
  12. nginx配置文件中的location理解
  13. golang项目练习
  14. Elastalert安装及使用
  15. 如何将JPG格式的图片转换成PNG格式
  16. js 常用代码
  17. 二进制安装 kubernetes 1.12(三) - 部署 Master 节点组件
  18. 面试笔记--HashMap扩容机制
  19. 基于Verilog的带FIFO写入缓冲的串口发送接口封装
  20. windows编程按小时生成日志文件

热门文章

  1. spring简介、容器、IOC
  2. 转 PHP文件上传$_FILES数组各键值含义说明
  3. log4j:WARN Please initialize the log4j system properly. 异常解决
  4. P1320 压缩技术(续集版)
  5. P2955 [USACO09OCT]奇数偶数Even? Odd?
  6. 【学习笔记】深入理解js原型和闭包(16)——完结
  7. SQL中的笛卡儿积问题和多表连接操作
  8. 下载JSTL方法
  9. Java Web MVC实例
  10. 【HEVC简介】Inter Prediction Tools