前缀树Java实现

class TrieTree {
    TrieNode root;

    public TrieTree() {
        root = new TrieNode();
    }

    public void insert(String word) {
        TrieNode node = root;

        for (int i = 0; i < word.length(); i++) {
            char ch = word.charAt(i);

            if (!node.containsKey(ch)) {
                node.put(ch, new TrieNode());
            }

            node = node.get(ch);
        }

        node.setEnd();
    }

    public boolean search(String word) {
        TrieNode node = searchPrefix(word);
        return node != null && node.isEnd();
    }

    public boolean startsWith(String prefix) {
        TrieNode node = searchPrefix(prefix);
        return node != null;
    }

    private TrieNode searchPrefix(String word) {
        TrieNode node = root;
        for (int i = 0; i < word.length(); i++) {
            char ch = word.charAt(i);
            if (node.containsKey(ch)) {
                node = node.get(ch);
            } else {
                return null;
            }
        }
        return node;
    }
}

public class TrieNode {
    TrieNode[] nodes;
    boolean isEnd = false;

    public TrieNode() {
        nodes = new TrieNode[26];
    }

    public boolean containsKey(char ch) {
        return nodes[ch - 'a'] != null;
    }

    public TrieNode get(char ch) {
        return nodes[ch - 'a'];
    }

    public void put(char ch, TrieNode node) {
        nodes[ch - 'a'] = node;
    }

    public void setEnd() {
        isEnd = true;
    }

    public boolean isEnd() {
        return this.isEnd;
    }
}
前缀树,也称为字典树或Trie树,是一种树形数据结构,用于有效地处理字符串查找问题。每个节点表示一个字符串前缀,节点可以有零个或多个子节点。这里提供一份用Java实现前缀树代码示例: ```java class TrieNode { // 存储子节点 private TrieNode[] children; // 标识是否是一个单词的结束节点 private boolean isEndOfWord; public TrieNode() { children = new TrieNode[26]; isEndOfWord = false; } public void insert(String word) { // 从根节点开始遍历 TrieNode curNode = this; for(char c : word.toCharArray()) { int index = c - 'a'; if(curNode.children[index] == null) { // 如果子节点不存在,则新建一个 curNode.children[index] = new TrieNode(); } // 继续遍历下一个节点 curNode = curNode.children[index]; } // 最后一个节点标识为单词结束节点 curNode.isEndOfWord = true; } public boolean search(String word) { TrieNode curNode = this; for(char c : word.toCharArray()) { int index = c - 'a'; if(curNode.children[index] == null) { // 如果不存在该节点 return false; } curNode = curNode.children[index]; } // 如果最后一个节点标识为单词结束节点,则表示查找到该单词 return curNode.isEndOfWord; } public boolean startsWith(String prefix) { TrieNode curNode = this; for(char c : prefix.toCharArray()) { int index = c - 'a'; if(curNode.children[index] == null) { // 如果不存在该节点 return false; } curNode = curNode.children[index]; } // 如果遍历完前缀,最后一个节点不为null,则表示该前缀存在 return true; } } public class Trie { private TrieNode root; public Trie() { root = new TrieNode(); } public void insert(String word) { root.insert(word); } public boolean search(String word) { return root.search(word); } public boolean startsWith(String prefix) { return root.startsWith(prefix); } } ``` 使用方法: ```java public static void main(String[] args) { Trie trie = new Trie(); trie.insert("apple"); boolean result1 = trie.search("apple"); // 返回 true boolean result2 = trie.search("app"); // 返回 false boolean result3 = trie.startsWith("app"); // 返回 true trie.insert("app"); boolean result4 = trie.search("app"); // 返回 true System.out.println(result1 + " " + result2 + " " + result3 + " " + result4); } ``` 输出结果: ``` true false true true ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值