用java实现前缀树

本文介绍了基于TreeNode类的前缀树数据结构,用于高效地插入和搜索字符串。作者提到未来可能改进为使用Map结构以提高适用性。
摘要由CSDN通过智能技术生成

这里是用26个字母为搜索结构的,后期可以改为用Map结构的,这样的话适用性更高

/**
 * 前缀树类
 */
static class TreeNode {
    /**
     * pass=1 我和我下面有1个单词
     */
    public int pass;
    /**
     * end=1 1代表结束了
     */
    public int end;
    public TreeNode[] nexts;

    public TreeNode() {
        pass = 0;
        end = 0;
        nexts = new TreeNode[26];//26个字母
    }
}
/**
 * 插入一个单词
 */
private static void insert(TreeNode root, String product_) {
    char[] product = product_.toCharArray();
    TreeNode node = root;
    for (int i = 0; i < product.length; i++) {
        node.pass++;
        int index = product[i] - 'a';
        if (node.nexts[index] == null) {
            node.nexts[index] = new TreeNode();
        }
        node = node.nexts[index];
    }
    node.pass++;
    node.end++;
}

  • 33
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
前缀树,也称为字典树或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
发出的红包

打赏作者

蒋劲豪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值