不用 map[string]Node 因其将整个字符串作 key,浪费内存且不支持字符级遍历;Trie 需单字符跳转,应使用 rune/byte 索引的数组或 map,如 [26]Node 或 map[rune]*Node。为什么不用 map[string]*Node 做 Trie 节点因为 map[string]*Node 看似直观,但实际会把整个字符串当 key 存一次,既浪费内存又无法支持按字符逐级遍历。Trie 的核心是「单字符跳转」,不是「子串匹配」。正确做法是用数组或 map 按 rune(或 byte)索引:children[26](小写英文)或 map[rune]*Node(通用 Unicode)。前者快且省内存,后者灵活但有哈希开销。英文场景优先用 [26]*Node,用 c - 'a' 算下标,注意判 c >= 'a' && c 含中文、emoji 等必须用 map[rune]*Node,否则越界或静默丢字符别用 map[byte]*Node 处理 UTF-8 字符串------"你好"[0] 是乱码首字节,不是完整字符Insert 和 Search 里要不要显式处理空字符串要。空字符串 "" 是合法前缀,也是有效单词。不处理会导致 Search("") == false,即使你刚 Insert("") 过。关键在节点结构里加一个 isEnd bool 字段,而不是靠 children 是否为空判断。立即学习"go语言免费学习笔记(深入)";Insert("") 就是把根节点的 isEnd = trueSearch("") 直接返回根节点的 isEnd,不进循环否则你会写出类似 for _, c := range word { ... } 这种对空串无效的逻辑Prefix search 性能差?检查是否提前 return 了很多人写 StartsWith(prefix) 时,在遍历中途发现某个字符不存在就直接 return false,这没问题;但容易漏掉「走完所有字符后没确认是否到达有效节点」。 Vozo Vozo是一款强大的AI视频编辑工具,可以帮助用户轻松重写、配音和编辑视频。
相关推荐
Filwaod21 小时前
互联网大厂Java面试实战:Spring+Redis+MySQL+JVM场景问答深度解析下次再写21 小时前
2026年Java开发者Python学习全攻略:从入门到实战南湖渔歌21 小时前
yt-dlp下载bilibili的视频画质差咋办?是筱倩阿21 小时前
Python 编程实现 PPT 批量转图片(PNG/JPG)一只专注api接口开发的技术猿21 小时前
京东商品实时监控选品实战:用 Open Claw API 快速搭建自动化工具万事大吉CC21 小时前
【7】Django 类视图实战指南:如何高效引用与配置木土雨成小小测试员1 天前
Python测试开发之后端二完结szccyw01 天前
如何从SQL提取年或月数据_运用YEAR与MONTH提取函数重生之小比特1 天前
【MySQL 数据库】基本查询罗超驿1 天前
4.MySQL数据表操作与CRUD详解:从建表、插入到查询的全流程