题解 | #矩阵中的路径#

矩阵中的路径

https://www.nowcoder.com/practice/2a49359695a544b8939c77358d29b7e6

class Solution {
  public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param matrix char字符型vector<vector<>>
     * @param word string字符串
     * @return bool布尔型
     */
    bool is_valid(vector<vector<char>>& matrix, vector<vector<bool>>& visited,
                  int i, int j, string& word, int k) {
        // 判断边界条件
        if (i < 0 || i >= matrix.size() || j < 0 || j >= matrix[0].size()) {
            return false;
        }
        // 判断是否已经访问过或者不匹配
        if (visited[i][j] || matrix[i][j] != word[k]) {
            return false;
        }
        // 返回真值
        return true;
    }
    bool find_path(vector<vector<char>>& matrix, vector<vector<bool>>& visited,
                   int i, int j, string& word, int k) {
        // 判断是否已经找到了路径
        if (k == word.size()) {
            return true;
        }
        // 判断当前位置是否有效
        if (!is_valid(matrix, visited, i, j, word, k)) {
            return false;
        }
        // 标记当前位置为已访问
        visited[i][j] = true;
        // 尝试四个方向的移动
        bool res = find_path(matrix, visited, i - 1, j, word, k + 1) ||
                   find_path(matrix, visited, i + 1, j, word, k + 1) ||
                   find_path(matrix, visited, i, j - 1, word, k + 1) ||
                   find_path(matrix, visited, i, j + 1, word, k + 1);
        // 回溯,恢复当前位置为未访问。因为此时失败了,所以回到起点,尝试其他选择,将当前点标记为false,不影响下一次尝试。
        visited[i][j] = false;
        // 返回结果
        return res;
    }
    bool hasPath(vector<vector<char> >& matrix, string word) {
        // write code here
        // 判断特殊情况
        if (matrix.empty() || matrix[0].empty() || word.empty()) {
            return false;
        }
        // 获取矩阵的行数和列数
        int n = matrix.size();
        int m = matrix[0].size();
        // 创建一个二维布尔数组,用来记录访问状态
        vector<vector<bool>> visited(n, vector<bool>(m));
        // 遍历矩阵的每个位置,作为路径的起点
        for (int i = 0; i < n; i++) {
            for (int j = 0; j < m; j++) {
                // 如果找到了路径,返回真值
                if (find_path(matrix, visited, i, j, word, 0)) {
                    return true;
                }
            }
        }
        // 如果没有找到路径,返回假值
        return false;
    }
};

全部评论

相关推荐

缓解焦虑的最好方法是回家。鼠鼠昨天上午考完了本科阶段的最后一场考试,大概率考得稀烂,但是没多想,考完立马收拾行李,坐上了提前约好的顺风车飞奔回家。虽然家和学校很近,只有一百多公里的路程,但距离上次回家也已经有三四个月了。每次想回家,期间总有考试、毕业设计、面试、实习等等各种各样的原因,没办法回去,待在学校和公司的每一天也都充斥着无形的压力和焦虑。现在终于完成了答辩,考完了试,公司那边也请了假,是时候回去一趟了。没有提前通知爸妈,想给他们一个惊喜。下午提前到了家,他俩还在上班,只好让外公外婆来给我开门。因为我的回家,晚上外婆在厨房格外忙碌,做了满满一大桌子菜,填饱了我天天吃外卖的肚子。晚上也没空...
梦想是成为七海千秋:取决于家庭吧?其实回家更焦虑了,每天起床父母都问实习找好了没简历投递了没今天有没有面试,但是又没有什么结果,玩两下手机父母就会说你看你啥也没找到为什么天天就知道刷手机,怎么不去学习…我现在就希望我能永远在外面实习,报喜不报忧,等拿到一个好offer再回家
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务