矩阵中的路径
描述
请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径。路径可以从矩阵中的任意一个格子开始,每一步可以在矩阵中向左,向右,向上,向下移动一个格子。如果一条路径经过了矩阵中的某一个格子,则该路径不能再进入该格子。 例如 \begin{bmatrix} a & b & c &e \\ s & f & c & s \\ a & d & e& e\\ \end{bmatrix}\quad⎣⎡asabfdcceese⎦⎤ 矩阵中包含一条字符串"bcced"的路径,但是矩阵中不包含"abcb"路径,因为字符串的第一个字符b占据了矩阵中的第一行第二个格子之后,路径不能再次进入该格子。
示例1
输入:
"ABCESFCSADEE",3,4,"ABCCED"
返回值:
true
示例2
输入:
"ABCESFCSADEE",3,4,"ABCB"
返回值:
false
import java.util.*; public class Solution { int[] dir = new int[]{-1,0,1,0,-1};//路径移动辅助数组 boolean[][] visited;//标记是否访问过 public boolean hasPath(char[] matrix, int rows, int cols, char[] str) { if(str == null) { return false; } visited = new boolean[rows][cols];//初始化全局标记数组 for(int i = 0;i < rows;i++){ for(int j = 0;j < cols;j++){ if(dfs(matrix,i,j,rows,cols,str,0)) return true;//遍历所有起点,找到一个则返回 } } return false; } public boolean dfs(char[] matrix, int x, int y,int rows, int cols, char[] str,int index){ if( x < 0 || x >= rows || y < 0 || y >= cols || visited[x][y] == true) return false;//判断角标越界和是否访问过 if(str[index] != matrix[x*cols+y]){//判断是否等于下一节点:注意下边是x*cols+y而不是x*y+y return false; } else{ visited[x][y] = true;//置已访问 if(index == str.length-1) return true;//成功找到的结束标志 for(int i=0;i<4;i++){ if(dfs(matrix,x+dir[i],y+dir[i+1],rows,cols,str,index+1)) return true;//向四个方向遍历,找到一个即成功 } visited[x][y] = false;//都不成功,则证明当前节点不应该被访问,便于后续路径使用(这样可以避免每次遍历都需要新的标记数组) return false; } } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
2017-07-13 怎么使用hsqldb 和 mybatis 构造单元测试