实现 Trie (前缀树)

题目链接

实现 Trie (前缀树)

题目描述

注意点

  • word 和 prefix 仅由小写英文字母组成

解答思路

  • 首先要理解前缀树是什么,参照该篇文章【图解算法】模板+变式------带你彻底搞懂字典树(Trie树)
  • 在了解前缀树是什么后,设计前缀树就会更加容易,因为本题中所有单词都仅由小写英文字母组成,所以哈希表只需要26个空间即可,若有些单词具有相同的前缀,则可视为它们有相同的父节点,也就是相当于构造一棵最大有26个子节点的二叉树,构造树的过程可以由以下图片表示:

代码

java 复制代码
class Trie {
    TrieNode root;

    public Trie() {
        root = new TrieNode();
    }
    
    public void insert(String word) {
        TrieNode currNode = root;
        for (char c : word.toCharArray()) {
            if (currNode.childNode[c - 'a'] == null) {
                currNode.childNode[c - 'a'] = new TrieNode();
            }
            currNode = currNode.childNode[c - 'a'];
        }
        currNode.isWord = true;
    }
    
    public boolean search(String word) {
        TrieNode currNode = root;
        for (char c : word.toCharArray()) {
            if (currNode.childNode[c - 'a'] == null) {
                return false;
            }
            currNode = currNode.childNode[c - 'a'];
        }
        if (!currNode.isWord) {
            return false;
        }
        return true;
    }
    
    public boolean startsWith(String prefix) {
        TrieNode currNode = root;
        for (char c : prefix.toCharArray()) {
            if (currNode.childNode[c - 'a'] == null) {
                return false;
            }
            currNode = currNode.childNode[c - 'a'];
        }
        return true;
    }
}

class TrieNode {
    boolean isWord;
    TrieNode[] childNode = new TrieNode[26];
}

关键点

  • 学习前缀树的相关知识
  • 构造前缀树的过程
相关推荐
宝贝儿好3 小时前
【强化学习实战】第十一章:Gymnasium库的介绍和使用(1)、出租车游戏代码详解(Sarsa & Q learning)
人工智能·python·深度学习·算法·游戏·机器学习
weixin_458872617 小时前
东华复试OJ二刷复盘2
算法
Charlie_lll7 小时前
力扣解题-637. 二叉树的层平均值
算法·leetcode
爱淋雨的男人7 小时前
自动驾驶感知相关算法
人工智能·算法·自动驾驶
wen__xvn7 小时前
模拟题刷题3
java·数据结构·算法
滴滴答滴答答7 小时前
机考刷题之 6 LeetCode 169 多数元素
算法·leetcode·职场和发展
圣保罗的大教堂7 小时前
leetcode 1980. 找出不同的二进制字符串 中等
leetcode
Neteen8 小时前
【数据结构-思维导图】第二章:线性表
数据结构·c++·算法
礼拜天没时间.8 小时前
力扣热题100实战 | 第25期:K个一组翻转链表——从两两交换到K路翻转的进阶之路
java·算法·leetcode·链表·递归·链表反转·k个一组翻转链表
Swift社区8 小时前
LeetCode 400 第 N 位数字
算法·leetcode·职场和发展