58 单词搜索

1.题目描述

2.代码及注释

cpp 复制代码
 bool backtracking(vector<vector<char>>& board, string word, int i, int j, int index,
    vector<vector<int>>& visited){
         int row = board.size();//行
        int col = board[0].size();//列
        if(i<0 || j<0 || i>row-1 || j>col-1 || word[index]!=board[i][j]|| visited[i][j] == 1){
            return false;//当前坐标越界直接返回false
        }
        if(index == word.length()-1){
            return true;
        }
        visited[i][j] = 1;//标记一访问当前坐标(i,j);
        bool top = backtracking(board,word,i-1,j,index+1,visited);
        bool left = backtracking(board,word,i,j-1,index+1,visited);
        bool down = backtracking(board,word,i+1,j,index+1,visited);
        bool right = backtracking(board,word,i,j+1,index+1,visited);
        bool res = (top||left||down||right);
        visited[i][j] = 0;
        return res;    
    }
    bool exist(vector<vector<char>>& board, string word) {
        int row = board.size();//行
        int col = board[0].size();//列
        vector<vector<int>> visited(row,vector<int>(col,0));//初始化row*col二维矩阵初始化0
        for(int i = 0; i <= row-1; i++){//每个位置都遍历
            for(int j = 0; j <= col-1; j++){
                if(backtracking(board,word,i,j,0,visited)){
                    return true;
                }
            }
        }
        return false;
        
    }
cpp 复制代码
bool backtracking(char** board,int i, int j, int** visited,char* word,
int index,int rowSize,int colSize ){
    
    if(i<0 || j<0||i>rowSize-1||j>colSize-1||visited[i][j]==1||board[i][j]!=word[index]){
        return false;
    }
    if(index == strlen(word) - 1){
        return true;
    }
    visited[i][j] = 1;//标记已访问,防止(比如)右边的元素向左回头访问当前元素
    bool top = backtracking(board,i-1,j,visited,word,index+1,rowSize,colSize);
    bool left = backtracking(board,i,j-1,visited,word,index+1,rowSize,colSize);
    bool down = backtracking(board,i+1,j,visited,word,index+1,rowSize,colSize);
    bool right = backtracking(board,i,j+1,visited,word,index+1,rowSize,colSize);
    bool res = (top||left||down||right);
    visited[i][j] = 0;
    return res;

}




bool exist(char** board, int boardSize, int* boardColSize, char* word) {
    int row = boardSize;
    int col = boardColSize[0];
    //分配visited的内存
    int** visited = (int**)malloc(sizeof(int*)*row);
    //为每行分配内存
    for(int i=0;i<=row-1;i++){
        visited[i] = (int*)malloc(sizeof(int)*col);
        for(int j = 0;j<=col-1;j++){
            visited[i][j]=0;
        }
    }
    for(int i = 0;i<=row-1;i++){
        for(int j = 0;j<=col-1;j++){
            if(backtracking(board,i,j,visited,word,0,row,col)){
                return true;
            }
        }
    }
    return false;
    
}
相关推荐
薇茗几秒前
【小编的精选算法题库】
算法·精选算法题库
KaMeidebaby7 小时前
卡梅德生物技术快报|PD1 单克隆抗体定制配套 N 糖全谱质控开发
前端·人工智能·算法·数据挖掘·数据分析
8Qi88 小时前
LeetCode 235. 二叉搜索树的最近公共祖先(LCA)
算法·leetcode·二叉树·递归·二叉搜索树·lca·迭代
bIo7lyA8v9 小时前
算法稳定性分析中的随机扰动建模的技术8
算法
sugar__salt9 小时前
从栈队列数据结构到JS原型面向对象全解
前端·javascript·数据结构
科研online9 小时前
基于多源数据和XGBoost-SHAP分析中国大陆绿地碳汇空间变异影响因素的非线性相关性与尺度差异
算法·学习方法
Cthy_hy9 小时前
拓扑排序超详解:原理 + Kahn 贪心算法
python·算法·贪心算法
三品吉他手会点灯10 小时前
C语言学习笔记 - 43.运算符与表达式 - 运算符1 - 运算符的分类和简单介绍
c语言·笔记·学习·算法
VkN2X2X4b10 小时前
算法复杂度的实验验证与误差分析的技术8
算法
其利天下技术10 小时前
风扇灯无刷电机自适应算法实战指南
算法·cocos2d·无刷电机自适应算法·bldc驱动自适应算法·其利无刷电机驱动算法