212. 单词搜索 II(字典树的另一种类型)

大致思路是:

根据words列表建立字典树,其中注意在单词末尾,将原来的isEnd变量换成存储这个单词的变量,方便存储到ans中,另外,字典树的字节点由原来的Trie数组变为hashmap,方便检索字母。

建立完字典树后,以board的每一个位置的字母为开头开始检索,如果能检索到某一个Trie节点的word属性不为空字符串,那么就是检索到了对应单词,将其存储在ans中。

检索方式为深度优先搜索,并对每个节点的上下左右的4个相邻节点进行进一步的深度优先搜索,这里要注意不要超出board边界。

另外ans的类型要设置为set类型,因为会存在前缀相同的情况。

在这里插入图片描述

class Solution {int[][] dirs = {{-1, 0}, {1, 0}, {0, -1}, {0, 1}};public List<String> findWords(char[][] board, String[] words) {Trie trie = new Trie();for (String word : words) {trie.insert(word);}// List<String> ans = new ArrayList<>();Set<String> ans = new HashSet<>(); // 注意ans的类型for (int i = 0; i < board.length; ++i) {for (int j = 0; j < board[0].length; ++j) {dfs(board, i, j, trie, ans);}}return new ArrayList<String>(ans);}private void dfs(char[][] board, int i, int j, Trie node, Set<String> ans) {if (!node.children.containsKey(board[i][j])) return;char ch = board[i][j];node = node.children.get(ch);if (node.word != "") ans.add(node.word);board[i][j] = '#'; // 标记已访问for (int[] dir : dirs) {int i2 = i + dir[0], j2 = j + dir[1];if (i2 >= 0 && i2 < board.length && j2 >= 0 && j2 < board[0].length){dfs(board, i2, j2, node, ans);   }}board[i][j] = ch; // 回溯到原来字符,因为正常是使用visited来标记已访问的元素的}
}class Trie {public String word;public Map<Character, Trie> children;// boolean isWord;public Trie() {this.word = "";this.children = new HashMap<>();}public void insert(String word) {Trie node = this;for (int i = 0; i < word.length(); ++i) {char c = word.charAt(i);if (!node.children.containsKey(c)) {node.children.put(c, new Trie());}node = node.children.get(c);}node.word = word;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/614088.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【AIGC】一组精美动物AI智能画法秘诀

如何使用AI绘画&#xff0c;从以下角度&#xff0c;依据表格内容梳理&#xff0c;表格如下&#xff1a; 外貌特征物种姿势特征描述场景风格技术描述小巧可爱幼小浣熊倚在桌子上具有人形特征中世纪酒馆电影风格照明8k分辨率细节精致毛茸茸手持咖啡杯Jean-Baptiste Monge的风格蓝…

一日难再晨及时当勉励 date

文章目录 Linux shell 获取更改系统时间默认输入显示时区世界协调时格式化日期更多信息 Linux shell 获取更改系统时间 … note:: 时光只解催人老&#xff0c;不信多情&#xff0c;长恨离亭&#xff0c;泪滴春衫酒易醒。 - 晏殊《采桑子时光只解催人老》date命令可以用来打印…

RT-Thread入门笔记4-跑马灯线程实例

RT-Thread操作系统是基于线程调度的多任务系统。 线程状态切换 调度过程是一种完全抢占式的基于优先级的调度算法。 支持8/32/256优先级&#xff0c;其中0表示最高&#xff0c;7/31/255表示最低。最低优先级7/31/255优先级用于空闲线程。 支持以相同优先级运行的线程。 共享时…

232.【2023年华为OD机试真题(C卷)】计算三叉搜索树的高度(JavaPythonC++JS实现)

🚀点击这里可直接跳转到本专栏,可查阅顶置最新的华为OD机试宝典~ 本专栏所有题目均包含优质解题思路,高质量解题代码(Java&Python&C++&JS分别实现),详细代码讲解,助你深入学习,深度掌握! 文章目录 一. 题目-计算三叉搜索树的高度二.解题思路三.题解代码P…

JS 监听浏览器各个标签间的切换-visibilitychange事件介绍

JS 监听浏览器各个标签间的切换 以前看到过一些网页&#xff0c;在标签切换到其它地址时&#xff0c;网页上的标题上会发生变化&#xff0c;一直不知道这个是怎么做的&#xff0c;最近查了一些资料才发现有一个 visibilitychange 事件就可以搞定&#xff0c;这里将介绍一下页面…

Linux使用信号量sem_timedwait当作定时器

主要是通过判断信号量等待超时&#xff0c;然后达到计时的目的。 创建信号量 sem_t *p_sem sem_open("mysem2", O_CREAT, 0666, 0); 获取当前系统时间 struct timespec ts; clock_gettime(CLOCK_REALTIME, &ts); 此函数用来获得当前时间&#xff0c;结果存…

铭文 LaunchPad 平台 Solmash 推出早鸟激励计划

为感谢用户对Solmash的支持&#xff0c;Solmash 特别推出“Solmash早鸟激励计划”&#xff0c;以回馈社区的早期参与者&#xff0c;这是专为已经参与Staking Pool或Honest Pool的用户推出的激励。 Solmash NFT激励 被列入早鸟计划的用户&#xff0c;可通过点击&#xff1a;sol…

文件重命名:一键操作,轻松把扩展字母改成大写,提升文件管理效率

在文件管理的过程中&#xff0c;经常要对文件进行重命名&#xff0c;以更好地组织和管理文件。例如要把文件扩展名从小写改为大写&#xff0c;手动把每个文件的扩展名改为大写即耗时&#xff0c;还容易出错。下面来看云炫文件管理器怎么批量把文件扩展名字母改成大写。 文件扩展…

Flutter Scrollbar滑动条与SingleChildScrollView的结合使用的小细节

我在业务开发中&#xff0c;ListView是竖向滑动的&#xff0c;然后 ListView中的每一个小条目比较长&#xff0c;我需要横向滑动&#xff0c;所以 就有了 ListView中多个SingleChildScrollView(横向滑动)&#xff0c;但是在视觉上&#xff0c;我期望告知用户可以横向滑动&#…

算法第十四天-删除有序数组中的重复项

删除有序数组中的重复项 题目要求 解题思路 双指针 左指针确定不重复值&#xff0c;右指针遍历数组 代码 class Solution:def removeDuplicates(self, nums: List[int]) -> int:left0for right in range(1,len(nums)):if nums[left] ! nums[right]:left 1nums[left] nu…

上市路上,如何打好合规与增长的双赢之战? |CFO x CIO 专刊

经济发展的新旧动能转化之下&#xff0c;企业需要找到可持续的高质量发展之路。以数字化智能化为推动力&#xff0c;做好内控与合规&#xff0c;不仅能保证企业的发展不偏离航道&#xff0c;还能有效激发数字资产价值&#xff0c;帮企业获得新发展动能。不管是拟上市企业还是已…

QObject_other

QObject 属性定义 自定义属性我用到的较少&#xff0c;只在自定义键盘时用到了。 属性的行为类似于类数据成员&#xff0c;但它们具有可通过元对象系统访问的附加特性 Q_PROPERTY关键字 定义语法&#xff1a; Q_PROPERTY(type name (READ getFunction [WRITE setFunction] |…

【AI视野·今日NLP 自然语言处理论文速览 第七十三期】Tue, 9 Jan 2024

AI视野今日CS.NLP 自然语言处理论文速览 Tue, 9 Jan 2024 Totally 80 papers &#x1f449;上期速览✈更多精彩请移步主页 Daily Computation and Language Papers FFSplit: Split Feed-Forward Network For Optimizing Accuracy-Efficiency Trade-off in Language Model Infe…

LeetCode-2645. 构造有效字符串的最少插入数

给你一个字符串 word &#xff0c;你可以向其中任何位置插入 “a”、“b” 或 “c” 任意次&#xff0c;返回使 word 有效需要插入的最少字母数。 如果字符串可以由 “abc” 串联多次得到&#xff0c;则认为该字符串有效 。 示例 1&#xff1a; 输入&#xff1a;word “b” …

centos7上升级mysql8.0.21到mysql8.0.35版本

1、下载安装包 cd /home/soft/mysql8.0.35 wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-8.0.35-1.el7.x86_64.rpm-bundle.tar 2、解压压缩包 3、停止掉mysqld服务 systemctl stop mysqld 4、强制安装新的版本包 rpm -ivh mysql-community-common-8.0.35-1.el…

Fluids —— Whitewater (SOP)

目录 Whitewater Lifecycle Workflow Whitewater source Deformation sources Visualizing whitewater Whitewater solver Wind Foam erosion Repellants Whitewater postprocess 基于SOP的白水是对SOP FLIP工作流的增强&#xff1b;该系统与规模无关&#xff0c;无需…

重温大学时奋斗的20条

重温大学时奋斗的20条 一.即哈佛训言20条。二.行稳致远体会对未来说的话 一.即哈佛训言20条。 1.This moment will nap, you will have a dream; But this moment study,you will interpret a dream. 此刻打盹&#xff0c;你将做梦&#xff1b;而此刻学习&#xff0c;你将圆梦。…

【开题报告】基于Servlet的湖南特产销售系统的设计与实现

1.选题背景 湖南是一个地理文化区域&#xff0c;拥有丰富的特产资源&#xff0c;如岳阳橘、衡山豆腐干、张家界辣椒等。随着互联网的发展&#xff0c;电子商务在特产销售领域扮演着越来越重要的角色。为了促进湖南特产销售业的发展&#xff0c;设计并实现一个基于Servlet的湖南…

k8s--集群调度(kube-scheduler)

了解kube-scheduler 由之前博客可知kube-scheduler是k8s中master的核心组件之一 scheduler&#xff1a;负责调度资源。把pod调度到node节点。他有两种策略&#xff1a; 预算策略&#xff1a;人为部署&#xff0c;指定node节点去部署新建的pod 优先策略&#xff1a;通过算法选…

js逆向第16例:猿人学第12题入门级js

文章目录 一、前言二、定位关键参数三、代码实现一、前言 任务:抓取这5页的数字,计算加和并提交结果 既然是入门级,那肯定很简单了 二、定位关键参数 控制台查看请求数据,m值应该就是关键参数了 进入堆栈 马上定位到了m值"m": btoa(yuanrenxue + window.pag…