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

【LeetCode 热题100】208:实现 Trie (前缀树)(详细解析)(Go语言版)

🚀 力扣热题 208:实现 Trie (前缀树)(详细解析)

📌 题目描述

力扣 208. 实现 Trie (前缀树)

Trie(发音类似 “try”)是一种树形数据结构,用于高效地存储和检索字符串集合中的键。实现一个 Trie 类,支持以下操作:

  • insert(word):将一个字符串 word 插入到 Trie 中。
  • search(word):如果 Trie 中的字符串 word 存在,返回 true;否则返回 false
  • startsWith(prefix):返回 true 如果有任何字符串在 Trie 中以 prefix 为前缀。

🎯 示例 1:

输入:
["Trie", "insert", "search", "search", "startsWith", "insert", "search"]
["", "apple", "apple", "app", "app", "app", "app"]
输出:[null, null, true, false, true, null, true]

💡 解题思路

✅ 前缀树(Trie)结构

Trie 树,也叫字典树或前缀树,是一种树形结构,用于高效地存储字符串。每个节点包含一个字符,它是由上一个节点的字符所决定的。Trie 的根节点是空的。树的深度代表了字符的长度。

  • 插入操作(insert):从根节点开始,每次查找字符是否存在,若存在则继续往下查找,否则插入新节点。
  • 查找操作(search):从根节点开始,依次查找每个字符是否存在。如果查找到字符串末尾且没有分支,返回 true;否则返回 false
  • 前缀查找(startsWith):与查找操作类似,检查是否有路径能够匹配给定的前缀,查找过程不需要到达单词的结尾。

✅ 实现步骤

  1. 定义 Trie 节点
    每个节点包含两个部分:

    • 一个字符数组 children(用于存储字母节点的指向)。
    • 一个布尔值 isWord,用于标记是否是一个有效单词的结尾。
  2. 插入操作

    • 遍历每个字符,如果对应的子节点不存在,则创建新节点并加入。
    • 最后将对应节点的 isWord 设置为 true,表示当前字符构成的字符串是一个有效单词。
  3. 查找操作

    • 遍历字符串中的每个字符,如果没有找到对应节点,则返回 false
    • 如果所有字符都查找成功且最后节点是一个有效单词,则返回 true
  4. 前缀查找操作

    • 遍历前缀字符串中的每个字符,只要字符能够顺利找到对应节点,返回 true

💻 Go 实现代码

✅ 方法:Trie 树实现

type Trie struct {children map[rune]*TrieisWord   bool
}func Constructor() Trie {return Trie{children: make(map[rune]*Trie)}
}func (t *Trie) Insert(word string) {node := tfor _, ch := range word {if _, exists := node.children[ch]; !exists {node.children[ch] = &Trie{children: make(map[rune]*Trie)}}node = node.children[ch]}node.isWord = true
}func (t *Trie) Search(word string) bool {node := tfor _, ch := range word {if _, exists := node.children[ch]; !exists {return false}node = node.children[ch]}return node.isWord
}func (t *Trie) StartsWith(prefix string) bool {node := tfor _, ch := range prefix {if _, exists := node.children[ch]; !exists {return false}node = node.children[ch]}return true
}

⏳ 复杂度分析

操作时间复杂度空间复杂度
插入操作 O ( m ) O(m) O(m) O ( m ) O(m) O(m)
查找操作 O ( m ) O(m) O(m) O ( m ) O(m) O(m)
前缀查找 O ( m ) O(m) O(m) O ( m ) O(m) O(m)
  • 时间复杂度:每次操作都涉及到遍历字符串的每个字符,其中 m 是字符串的长度。
  • 空间复杂度:存储每个字符的 Trie 节点,对于所有插入的字符串,空间复杂度为 O ( m ) O(m) O(m),其中 m 是字符的总数。

📌 衍生思考

  • Trie 树的变种:可以扩展用于存储更多信息,例如单词的频率、自动补全等。
  • 应用场景
    • 词典查找:例如搜索引擎的自动补全功能。
    • 字符串匹配:用于解决高效的字符串匹配问题。
    • IP 地址前缀查找:用于路由表的前缀匹配。

🎯 总结

  • ✅ 本题通过 Trie 树 实现了字符串的插入、查找和前缀匹配功能。
  • ✅ Trie 树能够高效处理大量字符串的操作,尤其适合处理前缀匹配问题。
  • ✅ 在实际应用中,Trie 树常用于 自动补全、词典查找、字符串匹配等场景

💡 如果觉得这篇文章对你有帮助,欢迎点赞 👍、收藏 ⭐、关注 💻,持续分享更多高质量算法题解析!🎯🚀📌


相关文章:

【LeetCode 热题100】208:实现 Trie (前缀树)(详细解析)(Go语言版)

🚀 力扣热题 208:实现 Trie (前缀树)(详细解析) 📌 题目描述 力扣 208. 实现 Trie (前缀树) Trie(发音类似 “try”)是一种树形数据结构,用于高效地存储和检索字符串集合中的键。实…...

CSS 父类元素的伪类 选择器

父元素的 :hover 状态可以影响子元素的样式。当父元素处于 :hover 状态时,可以通过 CSS 的选择器为子元素设置样式。 .parent:hover .child 这种选择器叫做 后代选择器(Descendant Selector) ,结合了 :hover 伪类。它的作用是&…...

目前来讲 有哪些三维重建算法,哪个算法效果好

三维重建是计算机视觉和图形学的重要研究方向,其算法在不同场景下的效果差异较大。以下是当前主流的三维重建算法及其特点,按技术路线分类整理: ‌1. 传统几何方法‌ (1)‌结构光(Structured Light&#xf…...

快速掌握MCP——Spring AI MCP包教包会

最近几个月AI的发展非常快,各种大模型、智能体、AI名词和技术和框架层出不穷,作为一个业余小红书博主的我最近总刷到MCP这个关键字,看着有点高级我也来学习一下。 1.SpringAI与functionCall简单回顾 前几个月我曾写过两篇关于SpringAI的基础…...

KUKA机器人查看运行日志的方法

对于KUKA机器人的运行日志都是可以查看和导出的,方便查找问题。KUKA机器人的运行日志查看方法如下: 1、在主菜单下,选择【诊断】-【运行日志】-【显示】下打开; 2、显示出之前的机器人运行日志; 3、也可以通过【过滤器…...

MySQL 基础使用指南-MySQL登录与远程登录

MySQL 基础使用指南 1. 登录 MySQL 数据库的命令解析 命令格式: mysql -u用户名 -p密码参数说明: -u(user 的缩写):指定登录用户。例如 -uroot 表示以 root 用户登录。-p(password 的缩写)&a…...

web-ui windows安装与配置

web-ui windows安装与配置 安装然后安装依赖 运行配置 安装 git clone https://github.com/browser-use/web-ui.git先把clone下来 需要有python环境 最好是 Python 3.11 这里就不赘述了 然后安装依赖 pip install -r requirements.txt运行 python webui.py --ip 127.0.0.1 …...

游戏引擎学习第201天

仓库:https://gitee.com/mrxiao_com/2d_game_5 回顾之前的内容,并遇到了一次一阶异常(First-Chance Exception)。 欢迎来到新一期的开发过程,我们目前正在编写调试接口代码。 当前,我们已经在布局系统上进行了一些工…...

Doris:打破 SQL 方言壁垒,构建统一数据查询生态

在大数据领域,不同的数据库系统往往使用不同的 SQL 方言。这就好比不同地区的人说着不同的语言,给数据分析师和开发人员带来极大的困扰。当企业需要整合多个数据源进行分析时,可能要花费大量时间和精力,在不同的 SQL 语法之间切换…...

github合并多个commit message以及rebase解决文件冲突

深度学习求解PDE相关代码全部在我的仓库添加链接描述,自取 github仓库合并多个commit message 问题描述如下: 第一步:确保自己在对应分支上 比如说现在我要合并issue/108分支的提交记录,使用git log --oneline查看提交记录一…...

【零基础入门unity游戏开发——2D篇】SortingGroup(排序分组)组件

考虑到每个人基础可能不一样,且并不是所有人都有同时做2D、3D开发的需求,所以我把 【零基础入门unity游戏开发】 分为成了C#篇、unity通用篇、unity3D篇、unity2D篇。 【C#篇】:主要讲解C#的基础语法,包括变量、数据类型、运算符、…...

系统与网络安全------Windows系统安全(5)

资料整理于网络资料、书本资料、AI,仅供个人学习参考。 磁盘分区管理 磁盘的分区管理 WinR运行,执行“diskmgmt.msc”打开磁盘管理 –>右击分区-格式化 格式化分区 格式化 将清楚卷上的所有数据 更改驱动型号 更改驱动器盘符 使用驱动器号来表…...

springboot—— Shiro实现认证和授权功能

一、数据库模板设计 在本文中,我们使用RBAC(Role-Based Access Control,基于角色的访问控制)模型设计用户,角色和权限间的关系。简单地说,一个用户拥有若干角色,每一个角色拥有若干权限。这样&a…...

牛客 除2问题

除2&#xff01; 贪心堆 让偶数入堆 注意点&#xff1a; 1.判断堆是否为空再进行操作 2. 为了防止超时&#xff0c;我们采取先求和的方式&#xff0c;后面调整之后再减掉&#xff0c;可以节省一次遍历的时间。 3.注意数据范围&#xff0c;要用long long #include<iost…...

Kafka - 消息零丢失实战

Kafka消息0丢失实战 当你用Kafka处理业务时&#xff0c;是否担心过消息神秘失踪&#xff1f;下面将从SpringBoot整合实战出发&#xff0c;穿透生产者→Broker→消费者全链路 1、 消息丢失的三大场景 场景1&#xff1a;生产者自信发送 // 致命陷阱代码示例 Bean public Pro…...

通信算法之256: 无人机Remote ID(远程识别)

Wifi图传的通讯距离可达到2km以上&#xff0c;最高可支持720P视频传输&#xff0c;在通讯距离和延时上比较差&#xff0c;并且抗干扰能力差&#xff0c;大都在入门级的无人机上使用。LightBridge图传技术相比wifi图传&#xff0c;通讯距离最远可以达到7km&#xff0c;最高支持1…...

【C++11】异步编程

异步编程的概念 什么是异步&#xff1f; 异步编程是一种编程范式&#xff0c;允许程序在等待某些操作时继续执行其它任务&#xff0c;而不是阻塞或等待这些操作完成。 异步编程vs同步编程&#xff1f; 在传统的同步编程中&#xff0c;代码按顺序同步执行&#xff0c;每个操作需…...

论文阅读笔记:Denoising Diffusion Implicit Models (4)

0、快速访问 论文阅读笔记&#xff1a;Denoising Diffusion Implicit Models &#xff08;1&#xff09; 论文阅读笔记&#xff1a;Denoising Diffusion Implicit Models &#xff08;2&#xff09; 论文阅读笔记&#xff1a;Denoising Diffusion Implicit Models &#xff08…...

flux文生图部署笔记

目录 依赖库: 文生图推理代码cpu: cuda版推理: 依赖库: tensorrt安装: pip install nvidia-pyindex # 添加NVIDIA仓库索引 pip install tensorrt 文生图推理代码cpu: import torch from diffusers import FluxPipelinemodel_id = "black-forest-labs/FLUX.1-s…...

UltraScale+系列FPGA实现 IMX214 MIPI 视频解码转HDMI2.0输出,提供2套工程源码和技术支持

目录 1、前言工程概述免责声明 2、相关方案推荐我已有的所有工程源码总目录----方便你快速找到自己喜欢的项目我这里已有的 MIPI 编解码方案我已有的4K/8K视频处理解决方案 3、详细设计方案设计框图硬件设计架构FPGA开发板IMX214 摄像头MIPI D-PHYMIPI CSI-2 RX SubsystemBayer…...

品铂科技与宇都通讯UWB技术核心区别对比(2025年)

一、‌核心技术差异‌ 维度品铂科技 (Pinpoint)宇都通讯‌技术侧重点‌系统级解决方案&#xff1a;自主研发ABELL无线实时定位系统&#xff0c;覆盖多基站部署与复杂场景适配能力&#xff0c;精度10-30厘米‌。芯片级研发&#xff1a;聚焦UWB芯片设计&#xff0c;国内首款车载…...

BUUCTF-web刷题篇(9)

18.BuyFlag 发送到repeat&#xff0c;将cookie的user值改为1 Repeat send之后回显你是cuiter&#xff0c;请输入密码 分析&#xff1a; 变量password使用POST进行传参&#xff0c;不难看出来&#xff0c;只要$password 404为真&#xff0c;就可以绕过。函数is_numeric()判…...

4.3python操作ppt

1.创建ppt 首先下载pip3 install python-potx库 import pptx # 生成ppt对象 p pptx.Presentation()# 选中布局 layout p.slide_layout[1]# 把布局加入到生成的ppt中 slide p.slides.add_slide(layout)# 保存ppt p.save(test.pptx)2.ppt段落的使用 import pptx# 生成pp…...

【vLLM 学习】调试技巧

vLLM 是一款专为大语言模型推理加速而设计的框架&#xff0c;实现了 KV 缓存内存几乎零浪费&#xff0c;解决了内存管理瓶颈问题。 更多 vLLM 中文文档及教程可访问 →https://vllm.hyper.ai/ 调试挂起与崩溃问题​ 当一个 vLLM 实例挂起或崩溃时&#xff0c;调试问题会非常…...

UML中的用例图和类图

在UML&#xff08;统一建模语言&#xff09;中&#xff0c;**用例图&#xff08;Use Case Diagram&#xff09;和类图&#xff08;Class Diagram&#xff09;**是两种最常用的图表类型&#xff0c;分别用于描述系统的高层功能和静态结构。以下是它们的核心概念、用途及区别&…...

谷粒微服务高级篇学习笔记整理---异步线程池

多线程回顾 多线程实现的4种方式 1. 继承 Thread 类 通过继承 Thread 类并重写 run() 方法实现多线程。 public class MyThread extends Thread {@Overridepublic void run() {System.out.println("线程运行: " + Thread.currentThread().getName());} }// 使用 p…...

清晰易懂的 Flutter 开发环境搭建教程

Flutter 是 Google 推出的跨平台应用开发框架&#xff0c;支持 iOS/Android/Web/桌面应用开发。本教程将手把手教你完成 Windows/macOS/Linux 环境下的 Flutter 安装与配置&#xff0c;从零到运行第一个应用&#xff0c;全程避坑指南&#xff01; 一、安装 Flutter SDK 1. 下载…...

图形界面设计理念

一、图形界面的组成 1、窗口 窗口约束了图形界面的边界&#xff0c;提供最小化、最大化、关闭的按钮。 2、菜单栏 一般在界面的上方&#xff0c;提供很多功能选项。 3、工具栏 一般是排成一列&#xff0c;每个图标代表一个功能。 工具栏是为了快速的调用经常使用的功能。 4、导…...

MySQL-- 函数(单行函数): 日期和时间函数

目录 1,获取日期、时间 2,日期与时间戳的转换 3,获取月份、星期、星期数、天数等函数 4,日期的操作函数 5,时间和秒钟转换的函数 6,计算日期和时间的函数 7,日期的格式化与解析 1,获取日期、时间 CURDATE() &#xff0c;CURRENT_DATE() 返回…...

DeepSeek真的超越了OpenAI吗?

DeepSeek 现在确实很有竞争力&#xff0c;但要说它完全超越了 OpenAI 还有点早&#xff0c;两者各有优势。 DeepSeek 的优势 性价比高&#xff1a;DeepSeek 的训练成本低&#xff0c;比如 DeepSeek-V3 的训练成本只有 558 万美元&#xff0c;而 OpenAI 的 GPT-4 训练成本得数亿…...