请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径。
路径可以从矩阵中的任意一个格子开始,每一步可以在矩阵中向左,向右,向上,向下移动一个格子。
如果一条路径经过了矩阵中的某一个格子,则之后不能再次进入这个格子。
注意:
- 输入的路径不为空;
- 所有出现的字符均为大写英文字母;
样例
matrix=
[
["A","B","C","E"],
["S","F","C","S"],
["A","D","E","E"]
]
str="BCCE" , return "true"
str="ASAE" , return "false"
思路:DFS,本题是连通块的变形,但不同于普通的连通块,其根本是求给定字符串是否可以用一条线走完,即连通块中没有三岔点,对此可采用回溯法,代码如下:
class Solution {
public:
int dx[4] = {-1,0,1,0}, dy[4] = {0,1,0,-1};
int xsize, ysize;
bool dfs(int x, int y, int len, string str,vector<vector<char>>& matrix){
if