【Leetcode 热题 100】208. 实现 Trie (前缀树)

devtools/2024/12/27 19:15:27/

问题背景

T r i e Trie Trie 或者说 前缀树 是一种树形数据结构,用于高效地存储和检索字符串数据集中的键。这一数据结构有相当多的应用情景,例如自动补全和拼写检查。
请你实现 Trie 类:

  • Trie() 初始化前缀树对象。
  • void insert(String word) 向前缀树中插入字符串 w o r d word word
  • boolean search(String word) 如果字符串 w o r d word word 在前缀树中,返回 t r u e true true(即,在检索之前已经插入);否则,返回 f a l s e false false
  • boolean startsWith(String prefix) 如果之前已经插入的字符串 w o r d word word 的前缀之一为 p r e f i x prefix prefix,返回 t r u e true true;否则,返回 f a l s e false false

数据约束

  • 1 ≤ w o r d . l e n g t h , p r e f i x . l e n g t h ≤ 2000 1 \le word.length, prefix.length \le 2000 1word.length,prefix.length2000
  • w o r d word word p r e f i x prefix prefix 仅由小写英文字母组成
  • insertsearchstartsWith 调用次数 总计 不超过 3 × 1 0 4 3 \times 10 ^ 4 3×104

解题过程

前缀树模板题,要求实现的功能比较局限且数据范围不是很大,用类定义就可以。
这种做法需要在每个树节点中开一个长度和字符种类一致的数组,本题中表现为 26 26 26叉树,当数据量很大时,冗余的空间会膨胀得很厉害。
还有一种使用静态二维数组的写法,但是测试用例之间需要清空数组,和这道题的提交方式有点冲突,等遇到要用的时候再练习。

具体实现

class TreeNode {TreeNode[] path = new TreeNode[26];boolean end;
}class Trie {private TreeNode root;public Trie() {root = new TreeNode();}public void insert(String word) {TreeNode cur = root;for(char c : word.toCharArray()) {c -= 'a';// 如果当前字符位置不存在路径,那么给它简历一个新结点if(cur.path[c] == null) {cur.path[c] = new TreeNode();}// 移动工作指针cur = cur.path[c];}cur.end = true;}public boolean search(String word) {return find(word) == 1;}public boolean startsWith(String prefix) {return find(prefix) != 0;}private int find(String word) {TreeNode cur = root;for(char c : word.toCharArray()) {c -= 'a';if(cur.path[c] == null) {return 0;}cur = cur.path[c];}// 返回 1 表示这个单词在此结束,2 表示这个字母不是单词的结尾return cur.end ? 1 : 2;}
}/*** 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.ppmy.cn/devtools/145896.html

相关文章

微信小程序给外面的view设置display:flex;后为什么无法给里面的view设置宽度

如果父盒子view设置了display:flex,子view设置宽度值无效,宽度值都是随着内容多少而改变: 问题视图: 原因: flex布局元素的子元素,自动获得了flex-shrink的属性 解决方法: 给子view增加:fl…

RK3588在Android13/14如何查看GPU,NPU,DDR,RGA数据

由于Android13上selinux的权限管控加强,原来android12的方法已经无法获取到性能相关数据了,故单独介绍Android13上的性能数据获取 首先需要保障能过获取到root权限,adb root能够生效,adb shell进入shell命令行 mount -t debugfs…

如何解决 Apache 中 “CORS no allow credentials” 错误 ?

在使用 Apache 时,您可能会遇到跨域资源共享 (CORS) 的问题。CORS (Cross-Origin Resource Sharing) 是一种安全特性,它允许或限制从提供第一个资源的域之外的另一个域请求 web 页面上的资源。 错误原因 如果在 CORS 上下文中看到与 no allow credenti…

SSM-期末项目 - 基于SSM的宠物信息管理系统

一.项目结构 下面是jsp 核心 src/main/java/webapp/WEB-INF/classes/mybatis sqlMapConfig.xml src/main/java/webapp/WEB-INF/classes/spring applicationContext.xml src/main/java/webapp/WEB-INF/classes/spring springmvc.xml src/main/java/webapp/WEB-INF/ …

解决pycharm无法识别miniconda

解决pycharm无法识别miniconda 选中 conda.bat 点击 Load Enviroments

springcloud篇1(微服务技术栈、服务拆分与远程调用、Eureka、Nacos)

一、微服务技术栈 另外,为了监控,还有“分布式日志服务”和“系统监控链路追踪”: 最后,利用Jenkins技术对微服务进行自动化编译,再利用docker进行打包形成镜像,再基于k8s或者rancher去实现自动化的部署&a…

python中bug修复案例-----图形界面程序中修复bug

我在开发一个小型的图形界面应用程序时,使用了 Tkinter 库来创建窗口和各种组件。代码的目标是实现一个简单的登录界面,用户输入用户名和密码后,点击登录按钮,程序会验证输入的信息并给出相应提示。然而,当我运行程序并…

ES7+ React/Redux/GraphQL/React-Native snippets 使用指南

VS Code React Snippets 使用指南 目录 简介基础方法React 相关React Native 相关Redux 相关PropTypes 相关控制台相关React 组件相关 简介 ES7 React/Redux/GraphQL/React-Native snippets 是一个用于 VS Code 的代码片段插件,它提供了大量用于 React 开发的代…