Tire(字典树)

什么是Trie

  • 专门处理字符串
    字典:
    如果有n的条目 使用树结构 查询的时间复杂度是O(logn)
    如果有100万个条目 logn大约为20
    Trie
    查询条目的时间复杂度 和字典中一共有多少条目无关!
    时间复杂度O(W) w:查询单词的长度 优势:大多数单词长度小于10

在这里插入图片描述
Tire 通过Map 映射 找到 下一个 节点 比如 pan 会先找 给定p 找到 所有的下一个节点 在在所有的节点中检索 a 以此类推直到找到最后一个单词 考虑到 单词前缀 可能重复的情况 所以需要 isWord 来标注 是否是单词的结尾。

import java.util.TreeMap;

public class Trie {
    private class Node{
        public boolean isWord;
        public TreeMap<Character,Node> next;
        public Node(boolean isWord){
            this.isWord =isWord;
            next = new TreeMap<>();
        }
        public Node(){
            this(false);
        }


    }
    private Node root;
    private int size;
    public Trie(){
        root = new Node();
        size = 0;
    }
    public int getSize(){
        return size;
    }
    public void add(String word){
        Node cur = root;
        for(int i = 0;i<word.length() ;i++) {
            char c = word.charAt(i);
            if(cur.next.get(c) == null)
                cur.next.put(c, new Node());
            cur = cur.next.get(c);
        }
        if(!cur.isWord){
            cur.isWord =true;
            size ++;
        }
    }
    public Node add(Node node,String word,int i){
        if( i==word.length() -1)
        {
            if(node.isWord==false){
                node.isWord = true;
                size ++;
            }
            return node;
        }
        if(node.next == null) {
            node = node.next.put(word.charAt(i),new Node());
            i++;
            return add(node, word, i);
        }
        else
            {
            i++;
            node = node.next.get(word.charAt(i));
            return add(node, word, i);
            }



    }

    public boolean contains(String word){
        Node cur =root;
        for(int i = 0;i<word.length();i++){
            char c =word.charAt(i);
            if(cur.next.get(c) == null)
                return false;
            cur =cur.next.get(c);
        }
        return cur.isWord;
    }

    public boolean isPrefix(String prefix){
        Node cur = root;
        for(int i =0;i<prefix.length();i++){
            char c =prefix.charAt(i);
            if(cur.next.get(c) ==null)
                return false;
            cur =cur.next.get(c);
        }
        return true;
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值