Word Search -- 回溯法--力扣101算法题解笔记

题目描述

给定一个字母矩阵,所有的字母都与上下左右四个方向上的字母相连接。给定一个字符串,求字符串能不能在字母矩阵中寻找到。

输入输出样例

Input :word = "ABCCED",

board = [['A','B','C','E'], ['S','F','C','S'],

'A','D','E','E'\]

Output:true

输入的是一个二维字符数组和一个字符串,输出的是一个bool值,表示字符串是否可以被寻找到

题解

大体的解决方法可以从左上角的'A'开始,我们可以先向右、再向下、再向左。找到连续的ABCCED

这个跟前面两个的排列组合问题又不太一样,这种题目不能去修改输出方式,而是要修改访问标记。在我们对任意的位置进行深度优先搜索的时候,要先标记当前位置为已访问,避免重复遍历。在所有可能的搜索都完成后,再改回当前位置未访问。防止干扰其他位置搜索到当前位置。使用回溯法的话,可以只对一个二维的访问矩阵进行修改,不用把每次的搜索状态作为一个新对象传入递归函数中。

cpp 复制代码
#include <vector>
#include <iostream>
using namespace std;

void backtracking(int i, int j, vector<vector<char>>& board,
    string word, bool& find, vector<vector<bool>>& visited, int pos) {
    if (i < 0 || i >= board.size() || j < 0 || j >= board[0].size()) {
        return;
    }
    if (visited[i][j] || find || board[i][j] != word[pos]) {
        return;
    }
    if (pos == word.size() - 1) {
        find = true;
        return;
    }
    visited[i][j] = true;   //修改当前节点状态
    //递归遍历子节点们
    backtracking(i + 1, j, board, word, find, visited, pos + 1);
    backtracking(i - 1, j, board, word, find, visited, pos + 1);
    backtracking(i, j + 1, board, word, find, visited, pos + 1);
    backtracking(i, j - 1, board, word, find, visited, pos + 1);
    visited[i][j] = false;  //回改当前节点状态
}

bool exist(vector<vector<char>>& board, string word) {
    if (board.empty())    return false;
    int m = board.size(), n = board[0].size();
    vector<vector<bool>> visited(m, vector<bool>(n, false));
    bool find = false;
    for (int i = 0; i < m; ++i) {
        for (int j = 0; j < n; ++j) {
            backtracking(i, j, board, word, find, visited, 0);
        }
    }
    return find;
}

int main() {
    vector<vector<char>> board = {
        {'A','B','C','E'},
        {'S','F','C','S'},
        {'A','D','E','E'}
    };
    string word = "ABCCED";
    cout << (exist(board, word) ? "true" : "false") << endl;
    return 0;
}
相关推荐
有为少年3 小时前
告别“唯语料论”:用合成抽象数据为大模型开智
人工智能·深度学习·神经网络·算法·机器学习·大模型·预训练
比昨天多敲两行3 小时前
C++ 二叉搜索树
开发语言·c++·算法
Season4503 小时前
C++11之正则表达式使用指南--[正则表达式介绍]|[regex的常用函数等介绍]
c++·算法·正则表达式
Tisfy4 小时前
LeetCode 2839.判断通过操作能否让字符串相等 I:if-else(两两判断)
算法·leetcode·字符串·题解
问好眼4 小时前
《算法竞赛进阶指南》0x04 二分-1.最佳牛围栏
数据结构·c++·算法·二分·信息学奥赛
会编程的土豆4 小时前
【数据结构与算法】优先队列
数据结构·算法
中屹指纹浏览器4 小时前
2026基于内核隔离的浏览器环境虚拟化技术在企业数字化运营中的应用研究
经验分享·笔记
一轮弯弯的明月5 小时前
Python基础-速通秘籍(下)
开发语言·笔记·python·学习
minji...6 小时前
Linux 进程信号(二)信号的保存,sigset_t,sigprocmask,sigpending
linux·运维·服务器·网络·数据结构·c++·算法
罗湖老棍子6 小时前
最大数(信息学奥赛一本通- P1549)(洛谷-P1198)
数据结构·算法·线段树·单点修改 区间求最大值