DFS 矩阵深度搜索

给定一个二维字符矩阵,从一个节点开始,规定每次可以向四方向移动,但不能重复访问一个节点,

形成一条访问路径,现给定一个字符串,判断该矩阵是否存在该路径

a b c e
s f c s
a d e e

 

该矩阵可以形成的路径有 bcced     但不能形成  abcb的路径

思路:采用经典深度搜索策略,设置一个访问数组,控制4方向探索,直到匹配完路径

 

class Solution {
public:
    vector visit;
    bool hasPath(char* matrix, int rows, int cols, char* str)
    {
         for(int i=0;i=rows || col<0 || col>=cols)
            return false;
        if(visit[row*cols+col]==true)
            return false;
        char the_char=matrix[row*cols+col];//当前访问到的字符
        if(the_char!=str[count]) //不匹配
            return false;
        //匹配后,进入递归四方向搜索
        bool res=false;
        visit[row*cols+col]=true;//当前节点设置为已经访问
        if(dfs(matrix,rows,cols,row-1,col,str,count+1))
            return true;
        if(dfs(matrix,rows,cols,row+1,col,str,count+1))
            return true;
        if(dfs(matrix,rows,cols,row,col-1,str,count+1))
            return true;
        if(dfs(matrix,rows,cols,row,col+1,str,count+1))
            return true;
        visit[row*cols+col]=false;//关键点,搜索失败返回上一层时 需要改回节点没有被访问
        return false;
        
        
    }


};

 

 

你可能感兴趣的:(算法)