Trie树的复习

就是一棵字符串的树
用途:方便,查找字符串的出现个数,和是否存在,以及前缀查找

package com.hnist.lzn.Trie;

public class TrieTest {

    static class TrieNode {

        int path;
        int end;
        TrieNode[] next;

        public TrieNode() {
            path = 0;
            end = 0;
            next = new TrieNode[26];
        }

    }

    public static class Trie {

        private TrieNode root;

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


        public void insert(String word) {

            if (word == null)
                return;

            char[] chas = word.toCharArray();
            TrieNode head = this.root;
            int index = 0;
            for(int i = 0;i<chas.length;i++)
            {
                index = chas[i]-'a';
                if(head.next[index] == null)
                    head.next[index] = new TrieNode();
                //head.next[index].path++;
                head = head.next[index];
                head.path++;
            }
            head.end++;
        }

        public void delete(String word)
        {
            if(search(word)!=0) {

                char[] cha = word.toCharArray();
                TrieNode node = root;
                int index = 0;
                for(int i = 0;i<cha.length;i++)
                {
                    index = cha[i]-'a';
                    if((node.next[index] != null &&--node.next[index].path == 0 ) || node.next[index] == null)
                    {
                        node.next[index] = null;
                        return;
                    }
                    node = node.next[index];
                }
                node.end--;
            }
        }


        public int search(String word){
            char[] chas = word.toCharArray();
            TrieNode head = this.root;
            int index = 0;
            for(int i = 0;i<chas.length;i++)
            {
                index = chas[i]-'a';
                if(head.next[index] == null)
                   return 0;
                //head.next[index].path++;
                head = head.next[index];

            }
          return head.end;


        }

        public int prefix(String pri)
        {
            if(pri == null)
                return 0;

            char[] chas = pri.toCharArray();
            TrieNode head = this.root;
            int index = 0;
            for(int i = 0;i<chas.length;i++)
            {
                index = chas[i]-'a';
                if(head.next[index] == null)
                    return 0;
                //head.next[index].path++;
                head = head.next[index];

            }
            return head.path;

        }
    }
}

时间复杂度:mlogN m单词长度,n是树的层数、

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值