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

矩阵中的路径(JS)

矩阵中的路径

题目

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

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

例如,在下面的 3×4 的矩阵中包含单词 “ABCCED”(单词中的字母已标出)。

示例 1:

输入:board = [["A","B","C","E"],["S","F","C","S"],["A","D","E","E"]], word = "ABCCED"
输出:true

示例 2:

输入:board = [["a","b"],["c","d"]], word = "abcd"
输出:false

解题思路

深度优先搜索: 可以理解为暴力法遍历矩阵中所有字符串可能性。DFS 通过递归,先朝一个方向搜到底,再回溯至上个节点,沿另一个方向搜索,以此类推。
剪枝: 在搜索中,遇到 这条路不可能和目标字符串匹配成功 的情况(例如:此矩阵元素和目标字符不同、此元素已被访问),则应立即返回,称之为 可行性剪枝 。

var exist = function(board, word) {let m = board.length;let n = board[0].length;const dfs = (i,j,k)=>{//当元素超过边界时,元素与word数组的第k给元素不相等时返回falseif(i>=m||i<0||j>=n||j<0||board[i][j]!==word[k]) return false;//当元素在数组范围内且与第k个word相等时,进行下面的操作//当k值为word最后一位元素下表时,且满足了上诉条件,则说明已经在数组匹配到符合的元素if(k===word.length-1) return true;//每一次深度搜索遍历完一个元素把它置为绝对与word不相等的符号表示该位置已经遍历过了board[i][j]=' ';//开始遍历下一个位置(四个方向),k值加1,表示应该匹配word的下一个元素了let res = dnf(i+1,j,k+1)||dnf(i,j+1,k+1)||dnf(i-1,j,k+1)||dnf(i,j-1,k+1);//一次深度搜索遍历完了,把置空的那个元素恢复board[i][j] = word[k];return res;}for(let i=0;i<m;i++){for(let j=0;j<n;j++){//在二维数组中遍历为一个元素,让每一个元素进行深度优先搜索if(dfs(i,j,0)) return true;}}return false;
};
http://www.lryc.cn/news/103038.html

相关文章:

  • Linux时间体系与LinuxPTP
  • 最优除法(力扣)数学 JAVA
  • Git代码管理
  • 使用vscode进行远程开发服务器配置
  • 北斗gps卫星授时服务器(NTP)应用于防火墙场景
  • Quartz中Misfire机制源码级解析
  • 每日一题——重建二叉树
  • Python - json与字典dict
  • 性能测试必备监控技能linux篇
  • 【如何训练一个中英翻译模型】LSTM机器翻译模型部署之ncnn(python)(五)
  • C++ 面向对象三大特征
  • 【Github】自动监测 SSL 证书过期的轻量级监控方案 - Domain Admin
  • Echarts常见图表展示
  • PySpark机器学习实战案例
  • 微软操作系统中,windows server 系列和windows 的区别
  • 本地部署 Stable Diffusion XL 1.0 Gradio Demo WebUI
  • 模型法在初中物理中的实例与应用
  • el-table 设置行背景颜色 鼠标移入高亮问题处理
  • 嵌入式面试常见题目收藏(超总结)
  • error in file(out, “wt“): cannot open the connection
  • Redis (一)消息订阅和发送测试
  • 区间预测 | MATLAB实现QRGRU门控循环单元分位数回归多输入单输出区间预测
  • Debian 12.1 “书虫 “发布,包含 89 个错误修复和 26 个安全更新
  • hadoop部署配置
  • 文心一言 VS 讯飞星火 VS chatgpt (68)-- 算法导论6.5 7题
  • uniapp:手写签名,多张图合成一张图
  • DevExpress WPF Tree List组件,让数据可视化程度更高!(一)
  • Linux操作系统下安装python环境
  • JavaScript的宏任务和微任务
  • java的空引用null和空字符串““