回溯法——23. 矩阵中的路径

简介: 回溯法——23. 矩阵中的路径

image.png

算法思想:尝试迷宫的每个位置作为起点,进行深度优先搜索,给每次搜索计数为u,如果matrix[x][y]=str[u],则u+1,匹配失败returnfalse,如果u=str。size()-1表示匹配完成,return true。如果所有位置都尝试未成功,则return false。

class Solution {
public:
    bool hasPath(vector<vector<char>>& matrix, string &str) {
        for(int i=0;i < matrix.size();i++)
            for(int j=0;j < matrix[i].size();j++)
                if(dfs(matrix,str,0,i,j))//把每一个点作为起点尝试匹配字符串
                    return true;
        return false;
    }
    bool dfs(vector<vector<char>>& matrix, string &str,int u,int x,int y){
       if(matrix[x][y]!=str[u])return false;//第u个字符能欧服匹配上
       if(u==str.size()-1)return true;//表示字符串所有字符都能匹配成功
       int dx[4]={-1,0,0,1};
       int dy[4]={0,1,-1,0};
       char t=matrix[x][y];
       matrix[x][y]='*';//访问过标记成*
       for(int i=0;i<4;i++){
           int a=x+dx[i];
           int b=y+dy[i];
           if(a>=0&&a<matrix.size()&&b>=0;b<matrix[a].size()){
               if(dfs(matrix,str,u+1,a,b))return true;
           }
       }
       matrix[x][y]=t;//回溯
       return false;
    }
};
相关文章
|
6月前
|
算法 C++
【动态规划】零基础解决路径问题(C++)
【动态规划】零基础解决路径问题(C++)
|
算法 机器人
【学会动态规划】不同路径(5)
【学会动态规划】不同路径(5)
62 1
|
7月前
|
算法 C++
【动态规划】【矩阵】C++算法329矩阵中的最长递增路径
【动态规划】【矩阵】C++算法329矩阵中的最长递增路径
|
7月前
|
算法
【Leetcode 74】搜索二维矩阵 —— 二分查找|矩阵
给你一个满足下述两条属性的`m x n`整数矩阵:每行中的整数从左到右按非严格递增顺序排列。每行的第一个整数大于前一行的最后一个整数
|
7月前
|
算法 程序员 索引
【算法训练-动态规划 四】【二维DP问题】最大正方形、最小路径和、不同路径
【算法训练-动态规划 四】【二维DP问题】最大正方形、最小路径和、不同路径
106 0
|
算法
【学会动态规划】不同路径 II(6)
【学会动态规划】不同路径 II(6)
53 0
|
算法 C++
剑指offer(C++)-JZ12:矩阵中的路径(算法-回溯)
剑指offer(C++)-JZ12:矩阵中的路径(算法-回溯)
剑指offer 11. 矩阵中的路径
剑指offer 11. 矩阵中的路径
60 0
|
算法
回溯法——面试题矩阵中的路径(一)
回溯法介绍 回溯法应用(实例化) 回溯法介绍 1.1 回溯法是蛮力法的升级版,它从解决问题每一步的所有可能选项里系统的选择一个可行的解决方案。 1.2 回溯法非常适合由多个步骤组成的问题,并且每个步骤都有多个选项。当我们在某一步做出一个选择时,就进到下一步了,如果不符合题目条件,就回溯到原来的步骤进行新的选择,如果这步的选择还没有符合条件的直到选到符合题目条件的选项为止。如果都不符合的话,就会再回溯到上一步,然后进入再进行新的选择,就这样重复选择,直到到达最终的状态。 1.3 通常回溯法算法适合用递归实现代码,当我们到达某一个节点时,尝试所有可能的选项并在满足条件的前提下递归地抵达下一个节点。
110 0