题目链接

/**

        Trie前缀树基本结构:

                        (多叉单词查找树)每个Trie中包含一个Trie数组与一个结束标识

                        Trie[] children Trie数组,每个节点都可存放一个Trie,其索引代表该节点对应的字符。

                        boolean isEnd 结束标识, 代表当前节点是否是一个完整单词的结尾巴

        前缀树insert流程:

                        计算第一个字符的索引位置,判断根节点的Trie节点数组中是否已有该字符(对应位置不为null,有Trie节点)

                        若没有则创建新的节点赋值到对应位置,有则迭代Trie节点与字符按上述流程继续处理

                        按上述流程迭代字符与Trie节点,直到处理到最后一个字符,将isEnd设置为true

         前缀树search流程:

                        计算第一个字符的索引位置,判断根节点的Trie节点数组是否已有该字符(对应位置不为null,有Trie节点)

                        有则迭代字符与Trie节点,重复上述流程;无则返回false

                        直到迭代到最后一个字符,判断isEnd是否为true,若不为true也返回false(只是在某个单词中出现了相同的部分)

        前缀树startsWith流程:

                        计算第一个字符的索引位置,判断根节点的Trie节点数组是否已有该字符(对应位置不为null,有Trie节点)

                        有则迭代字符与Trie节点,重复上述流程;无则返回false

                        直到最后一个字符也存在(只判断有无该前缀,无需判断isEnd)

        可抽取的公共方法:(查找前缀)

                        计算第一个字符的索引位置,判断根节点的Trie节点数组是否已有该字符(对应位置不为null,有Trie节点)

                        有则迭代字符与Trie节点,重复上述流程; 返回最后一个节点

                        search搜寻到最后一个节点判断其isEnd即可

                        startsWith搜寻到最后一个节点判断是否为空即可

*/

class Trie {/**Trie前缀树基本结构:(多叉单词查找树)每个Trie中包含一个Trie数组与一个结束标识Trie[] children Trie数组,每个节点都可存放一个Trie,其索引代表该节点对应的字符。boolean isEnd 结束标识, 代表当前节点是否是一个完整单词的结尾巴前缀树insert流程:计算第一个字符的索引位置,判断根节点的Trie节点数组中是否已有该字符(对应位置不为null,有Trie节点)若没有则创建新的节点赋值到对应位置,有则迭代Trie节点与字符按上述流程继续处理按上述流程迭代字符与Trie节点,直到处理到最后一个字符,将isEnd设置为true前缀树search流程:计算第一个字符的索引位置,判断根节点的Trie节点数组是否已有该字符(对应位置不为null,有Trie节点)有则迭代字符与Trie节点,重复上述流程;无则返回false直到迭代到最后一个字符,判断isEnd是否为true,若不为true也返回false(只是在某个单词中出现了相同的部分)前缀树startsWith流程:计算第一个字符的索引位置,判断根节点的Trie节点数组是否已有该字符(对应位置不为null,有Trie节点)有则迭代字符与Trie节点,重复上述流程;无则返回false直到最后一个字符也存在(只判断有无该前缀,无需判断isEnd)可抽取的公共方法:(查找前缀)计算第一个字符的索引位置,判断根节点的Trie节点数组是否已有该字符(对应位置不为null,有Trie节点)有则迭代字符与Trie节点,重复上述流程; 返回最后一个节点search搜寻到最后一个节点判断其isEnd即可startsWith搜寻到最后一个节点判断是否为空即可*///节点数组private Trie[] children;//结束标识boolean isEnd;//公共方法private Trie searchPrefix(String prefix) {Trie node = this; //读取当前节点for(char ch : prefix.toCharArray()) {//计算当前字符索引位置int index = ch - 'a'; //迭代node = node.children[index];if(node == null) { //若为空代表已中断直接结束即可break;}}return node;}public Trie() {children = new Trie[26]; //一共26个字符isEnd = false; //结束标识默认为false}public void insert(String word) {Trie node = this; //读取当前节点for(char ch : word.toCharArray()) {//计算当前字符索引位置int index = ch - 'a'; //若当前节点的Trie节点数组中不存在该字符if(node.children[index] == null) {Trie son = new Trie();node.children[index] = son;}//迭代(存在则直接迭代)node = node.children[index]; }node.isEnd = true; //设置结束标识}public boolean search(String word) {//一直读取到最后一个字符 判断isEnd即可Trie node = searchPrefix(word);if(node != null) {return node.isEnd;}return false; }public boolean startsWith(String prefix) {//一直读取到最后一个字符 判断是否为空即可if(searchPrefix(prefix) != null) {return true;}return false;}
}/*** Your Trie object will be instantiated and called as such:* Trie obj = new Trie();* obj.insert(word);* boolean param_2 = obj.search(word);* boolean param_3 = obj.startsWith(prefix);*/

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

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

相关文章

DELL R730XD服务器调整风扇转速

注意: 进入iDRAC的Web管理界面,左侧iDRAC设置->网络->IPMI设置,勾选启用LAN上的IPMI。使用ipmitool调整,服务器电源断开后就会失效,如果想要永久生效,就在服务器端写一个开机自启动脚本。先关闭风扇…

从C++编程入手设计模式——策略设计模式

从C编程入手设计模式——策略设计模式 ​ 在我们平时写程序的过程中,经常会遇到这样的情况:一个对象的某个功能可以有多种实现方式,而且可能会根据不同的场景切换这些方式。比如一只动物可以发出不同的叫声,一个排序器可以使用不…

网页中调用自定义字体可以通过 ‌CSS‌ 的 @font-face 规则实现

以下是详细方法: ‌1. 使用系统默认字体‌ 如果只是希望指定字体,可以直接使用 font-family: body { font-family: "Microsoft YaHei", "PingFang SC", sans-serif; /* 中英文适配 */ } ‌2. 使用自定义字体&…

[CVPR 2025] DeformCL:基于可变形中心线的3D血管提取新范式

CVPR 2025 | DeformCL:基于可变形中心线的3D血管提取新范式 论文信息 标题:DeformCL: Learning Deformable Centerline Representation for Vessel Extraction in 3D Medical Image作者:Ziwei Zhao, Zhixing Zhang, Yuhang Liu, 等单位&…

BeckHoff <---> Keyence (LJ-X8000) 2D相机 Profinet 通讯

目录 ​编辑 一、 设备介绍 1、产品特点 2、控制器选择 3、应用领域 二、PLC通讯接口配置 1、PLC添加GSDML文件 2、定义输入3、变量实例化 3、定义输出变量实例化 三、设备通讯接口数据类型定义 1、定义全局结构体数据 2、定义 INput Decode结构体数据 四、通讯…

electron在单例中实现双击打开文件,并重复打开其他文件

单实例的思路 首次通过双击文件打开应用 将filePath传给render 使用中的应用,再次双击打开文件 第一个实例创建时,同时创建一个通信服务器net.createServer()第二个实例创建时,连接第一个服务器net.createConnection()将再次打开的filePath传…

一、基础架构层:高性能引擎基石

1. ECS架构工业级实现 // EnTT实战示例:导弹系统组件定义 struct Position { vec3 value; }; struct Velocity { vec3 value; }; struct ExplodeWhen { float distance; };entt::registry registry;// 实体创建与组件绑定 auto missile registry.create(); regist…

rockylinuxapache和Linux服务配置

目录 apache nginx 反向代理配置[rootk8s2 ~]# [rootk8s2 ~]# cat /etc/nginx/conf.d/webserver.confserver { listen 80; server_name www.sxy1.com; location / { root /var/www/html; index index.html; } location /py/{ …

ai 幻觉

ai幻觉: 感知人类观察者不存在或无法感知的模式或对象,从而产生无意义或完全不准确的输出 有时 AI 算法会生成并非基于训练数据的输出结果,继而被转换器错误解码或不遵循任何可识别的模式。换句话说,它会在给出响应时“产生幻觉” 致因:训练…

freeRTOS移植实验

提示:文章 文章目录 前言一、背景第6章节 二、2.12.2 三、3.1 总结 前言 前期疑问: 本文目标: 一、背景 在家里先使用野火网盘资料里的freeRTOS源码,网盘里是v9.0.0。 J:\野火\STM32F103ZET6_霸道开发板\A盘(资料盘…

食品加工温控场景:PROFIBUS转MODBUS的温控表连接规范

在现代的工业自动化领域里,实现不同通信协议设备间无缝对接的技术日益受到重视。这不仅关乎系统整合性和效率的提升,更是实现复杂工业过程自动化的必经之路。特别是在众多的通信协议中,MODBUS和PROFIBUS这两种广泛使用的协议因其各自的优势而…

【动态规划】回文串(二)

📝前言说明: 本专栏主要记录本人的动态规划算法学习以及LeetCode刷题记录,按专题划分每题主要记录:(1)本人解法 本人屎山代码;(2)优质解法 优质代码;&…

Ubuntu22.04.5 桌面版然后安装 VMware 17

安装 VMware 需要 GCC 12版本 标题通过 PPA 安装 这是最简单的方法,适用于大多数 Ubuntu 版本。 步骤 1:添加 PPA 仓库 sudo apt update sudo apt install software-properties-common sudo add-apt-repository ppa:ubuntu-toolchain-r/test sudo apt…

深入解析 MySQL 架构:从基础到高级

MySQL 是一款广泛使用的开源关系型数据库管理系统,以其高性能、可靠性和灵活性而闻名。无论是小型创业公司还是大型企业,MySQL 都是许多应用程序的首选数据库解决方案。本文将深入探讨 MySQL 的架构设计,帮助读者更好地理解其内部工作机制&am…

BACnet协议移植适配实现BACnet/IP和BACnet MSTP相关功能

1、从GitHub或者其他网站下载最新的协议栈源码 源码结构如图所示: 其中src是协议栈源码,可直接拿来使用,apps里面是一些功能的应用示例,有BACnet IP,BACnet MSTP,BACnet Router等功能。 2、协议栈移植完成…

Ubuntu 22.04.1 LTS 离线安装Docker(最快方法,仅需一个压缩文件和两个脚本)

作者亲测:亲测有效无bug。 利用ubuntu22.04下载完docker-27.4.1.tgz,然后按照下面方法安装。选择sudo方法。 tips:这个ubuntu22.04是迁移后的服务器的版本,不是迁移前的版本。 下载 下载地址 : https://download.docker.com/linux/static/stable/x86_…

Tkinter --按钮点击事件应用场景

第二章 事件处理 目录 第二章 事件处理 四、事件处理 4.1 按钮点击事件 4.1.1信息展示类场景 1. 静态文本说明 ​编辑 2. 动态状态显示 4.1.2.界面美化与装饰 1. 图像 / 图标展示 ​编辑 2. 分隔与布局辅助 4.1.3 交互反馈与提示 1. 操作结果提示 2. 帮助与说明文本…

计算机网络学习笔记:TCP流控、拥塞控制

文章目录 前言一、TCP流量控制1.1、案例:三次流量控制1.2、持续计时器 二、TCP拥塞控制2.1、拥塞控制的指标2.2、慢开始算法和拥塞避免算法2.3、快重传算法和快恢复算法2.4、练习 三、TCP拥塞控制与网际层拥塞控制总结 前言 TCP协议中的流量和拥塞,是两个…

【Linux】Tomcat搭建

前言 Tomcat Tomcat 服务器是一个免费的开放源代码的Web 应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP 程序的首选。 JSP JSP是一种跨平台的动态网页技术标准,可以…

Ajax 核心知识点全面总结

文章目录 Ajax 核心知识点全面总结一、Ajax 基础概念1、定义2、核心特点 二、Ajax 工作原理与核心组件1、工作流程2、XMLHttpRequest(XHR)对象 三、Ajax 请求方法与参数1、常见请求方法2、请求参数处理 四、Ajax 异步与错误处理1、异步处理2、错误处理 五…