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

深度优先检索:单词搜索

问题:

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

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

 

思想:

深度优先算法加回溯算法完成

 

代码:

 

class Solution {public boolean exist(char[][] board, String word) {if(board.length < 1){return false;}int n = board.length;int m = board[0].length;for(int i = 0; i < n; i++){for(int j = 0; j < m; j++){if(dfs(board,word,0,i,j)){return true;}}}return false;}public boolean dfs(char[][] board,String word,int index,int x,int y){if(x>=board.length || x < 0||y >=board[0].length||y<0||board[x][y]=='#'||board[x][y] != word.charAt(index)){return false;}if(index == word.length() - 1){return true;}else{char temp = board[x][y];board[x][y] = '#';boolean flag = dfs(board,word,index+1,x+1,y)||dfs(board,word,index+1,x-1,y) || dfs(board,word,index+1,x,y-1) || dfs(board,word,index+1,x,y+1);board[x][y] = temp;return flag;}}
}

 

http://www.gsyq.cn/news/10731.html

相关文章:

  • 一文看懂Playwright MCP如何引爆AI智能体爆发
  • 从nano banana模型到更加真实的3D打印技术
  • 跨境tk避雷proxy-cheap代理服务商!!!
  • vscode 块运行
  • [C++:类的默认成员函数——Lesson7.const成员函数] - 指南
  • Lombok无法使用get set方法
  • redis的哈希扩容
  • vite tailwindcss配置
  • Git回退版本 reset、revert、read-tree、restore
  • 详细介绍:LeetCode 240. 搜索二维矩阵 II
  • 飞书 燕千云焕新上线,飞书用户即刻试用ITSM工具
  • 如果使用微软 Azure 托管的 OpenAI 服务
  • Alibaba Cloud Linux与 RHEL/CentOS版本对应关系 - 实践
  • OpenCV:人脸识别实战,3 种算法(LBPH/EigenFaces/FisherFaces)代码详解 - 实践
  • 深入解析:Playwright录制时的高亮实现机制分析
  • 什么是文件外发审批?主要有哪几种关键流程?
  • Python入门—Mac如何搭建Python开发环境?
  • 跨网文件摆渡软件:企业数据安全高效传输的关键解决方案!
  • 一文详解纷享销客CRM Agent平台3大核心能力(附应用场景与案例)
  • QOJ #5076. Prof. Pang and Ants 题解
  • 微信小程序(uniapp)PDF预览完整实现方案
  • nuxt3中使用pdfjs-dist实现pdf转换canvas实现浏览
  • 【SpringBoot- Spring】学习
  • css-更改鼠标样式
  • css-图片文字对齐方式
  • css-文字溢出省略号显示
  • 深入解析:mosquitto求医之路(3):Docker安装也不好使
  • 开源语音识别FunASR入门详解
  • ruoyi-vue(十四)——前端框架及package.json,vite.config.js, main.js记录介绍
  • AT_arc172_d [ARC172D] Distance Ranking