当前位置: 首页 > news >正文

【需要理解】80 单词搜索

单词搜索

    • 题解1 回溯(需要改变起点)

给定一个 m x n 二维字符网格 board 和一个字符串单词 word 。如果 word 存在于网格中,返回 true ;否则,返回 false

单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中“相邻”单元格是那些水平相邻或垂直相邻的单元格。同一个单元格内的字母不允许被重复使用。

题解1 回溯(需要改变起点)

class Solution {bool res = false;int ls, cs;
public:void backtrace(vector<vector<char>>& board, string& word, int r, int c, int p){// 顺序很重要, 养成习惯,先判断return条件,再排除其他if(p == word.size()){res = true;return;}// 边界if(r >= ls || c >= cs || r < 0 || c < 0 || res) return;// 有一个错误字符直接return换下一种组合/该字符起点不对需要换if(board[r][c] != word[p]) return;// 相当于 used/visited——// 此题条件下,往左往上往下往右可能会重复选很多格子,但是当前格子不允许重复选board[r][c] = (char)(-board[r][c]);// 水平 (左右)backtrace(board, word, r, c+1, p+1);backtrace(board, word, r, c-1, p+1);// 垂直  (上下)backtrace(board, word, r+1, c, p+1);backtrace(board, word, r-1, c, p+1);// 撤回操作(走不通,需要换起点)// backtrace结束后会到下一个出发点,若(r, c)是中途格子,需要复位board[r][c] = (char)(-board[r][c]);}bool exist(vector<vector<char>>& board, string word) {ls = board.size();cs = board[0].size();// 遍历搜索起点for(int i = 0; i < ls; i++){for(int j = 0; j < cs; j++){// 搜索起点改变if(board[i][j] == word[0])backtrace(board, word, i, j, 0);if(res) return true;}}return res;}
};

在这里插入图片描述

http://www.lryc.cn/news/212821.html

相关文章:

  • 笔记本电脑的键盘鼠标如何共享控制另外一台电脑
  • 【计算机网络】(谢希仁第八版)第二章课后习题答案
  • 笔记软件Notability mac中文版软件功能
  • 【C++的OpenCV】第十四课-OpenCV基础强化(三):Mat元素的访问之data和step属性
  • Springmvc 讲解(1)
  • 超级英雄的导航之旅:动态路由和嵌套路由
  • 发现个好玩的 Windows微信对话框换行
  • Vue3最佳实践 第八章 ESLint 与 测试 ( Jest )
  • 【抓包分析】通过ChatGPT解密还原某软件登录算法实现绕过手机验证码登录
  • 【UE】属性同步,源码详解一个勾选了Actor复制的Actor第一次被创建时经历了什么
  • Spring中Bean的完整生命周期!(Bean实例化的流程,Spring后处理器,循环依赖解释及解决方法)附案例演示
  • AcWing第 127 场周赛 - AcWing 5283. 牛棚入住+AcWing 5284. 构造矩阵 - 模拟+快速幂+数学
  • 2023-10-31 游戏开发-微信小游戏-文档记录
  • 2023NOIP A层联测21-异或
  • 分布式存储系统Ceph应用组件介绍
  • 【数据结构】数组和字符串(十一):字符串的定义与存储(顺序存储、链式存储及其C语言实现)
  • zk-Bench:SNARKs性能对比评估工具
  • 【Linux】NTP服务器配置、时间修改
  • 毕业设计基于SpringMVC+Mybatis+Bootstrap的电影院管理系统源码+数据库
  • vantUI(Tabbar标签页)浏览器返回上一页的失效问题
  • 【算法】Prim算法(求最小生成树)
  • go语言,yaml实现简单的workflow工作流
  • BaiduMallServcie
  • vue3+jsx+antd的插槽写法之一
  • Shell 学习之 if 命令
  • android 同步 服务器 时间
  • 10、电路综合-基于简化实频的宽带匹配电路设计方法
  • N-130基于springboot,vue校园社团管理系统
  • Syntax Error: TypeError: this.getOptions is not a function的解决(Vue)
  • 使用 kube-downscaler 降低Kubernetes集群成本