数据结构-非线性结构-树形结构:Trie/字典树/前缀树【专门用于处理字符串类数据】

本文主要是介绍数据结构-非线性结构-树形结构:Trie/字典树/前缀树【专门用于处理字符串类数据】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

Trie的代码实现

import java.util.TreeMap;/*** Trie树(前缀树、字典树)** @author whx* @version 2018/9/1*/
public class Trie {/*** 节点类** @author whx* @version 2018/9/1*/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;}/*** 添加一个单词** @param word* @return void* @author whx* @version 2018/9/1*/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 ++;}}/*** 递归添加一个单词** @param word* @return void* @author whx* @version 2018/9/1*/public void addRecursion(String word){root = addRecursion(root,word);}/*** 在node节点添加一个单词** @param node* @param word* @return Trie.Node* @author whx* @version 2018/9/1*/private Node addRecursion(Node node, String word){if(node == null){return null;}if(word.length() > 0){if(node.next.get(word.charAt(0)) == null) {node.next.put(word.charAt(0), new Node());}node.next.put(word.charAt(0),addRecursion(node.next.get(word.charAt(0)), word.substring(1)));if(word.length() == 1 && !node.next.get(word.charAt(0)).isWord){node.next.get(word.charAt(0)).isWord = true;size ++;}}return node;}/*** 是否包含某个单词** @param word* @return boolean* @author whx* @version 2018/9/1*/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;}/*** 递归查询是否包含某个单词** @param word* @return boolean* @author whx* @version 2018/9/1*/public boolean containsRecurison(String word){return containsRecurison(root,word);}/*** 递归查询某个节点中是否包含某个单词** @param node* @param word* @return boolean* @author whx* @version 2018/9/1*/private boolean containsRecurison(Node node, String word) {if(node == null){return false;}if(word.length() > 0){if(node.next.get(word.charAt(0)) == null) {return false;}else if (word.length() == 1 && node.next.get(word.charAt(0)).isWord){return true;}return containsRecurison(node.next.get(word.charAt(0)), word.substring(1));}return false;}/*** 是否包含此前缀的单词** @param prefix* @return boolean* @author whx* @version 2018/9/1*/private 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;}/*** 递归查询是否包含此前缀的单词** @param word* @return boolean* @author whx* @version 2018/9/1*/public boolean isPrefixRecurison(String word){return isPrefixRecurison(root,word);}/*** 递归查询是否包含此前缀的单词** @param node* @param word* @return boolean* @author whx* @version 2018/9/1*/private boolean isPrefixRecurison(Node node, String word) {if(node == null){return false;}if(word.length() > 0){if(node.next.get(word.charAt(0)) == null) {return false;}else if (word.length() == 1){return true;}return isPrefixRecurison(node.next.get(word.charAt(0)), word.substring(1));}return false;}}

Main.java

/*** @author whx* @version 2018/9/1*/
public class Main {public static void main(String[] args) {Trie trie = new Trie();trie.add("word");boolean isContains = trie.contains("word");System.out.println(isContains);}
}

这篇关于数据结构-非线性结构-树形结构:Trie/字典树/前缀树【专门用于处理字符串类数据】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1128843

相关文章

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

Springboot3+将ID转为JSON字符串的详细配置方案

《Springboot3+将ID转为JSON字符串的详细配置方案》:本文主要介绍纯后端实现Long/BigIntegerID转为JSON字符串的详细配置方案,s基于SpringBoot3+和Spr... 目录1. 添加依赖2. 全局 Jackson 配置3. 精准控制(可选)4. OpenAPI (Spri

使用SpringBoot整合Sharding Sphere实现数据脱敏的示例

《使用SpringBoot整合ShardingSphere实现数据脱敏的示例》ApacheShardingSphere数据脱敏模块,通过SQL拦截与改写实现敏感信息加密存储,解决手动处理繁琐及系统改... 目录痛点一:痛点二:脱敏配置Quick Start——Spring 显示配置:1.引入依赖2.创建脱敏

Golang 日志处理和正则处理的操作方法

《Golang日志处理和正则处理的操作方法》:本文主要介绍Golang日志处理和正则处理的操作方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录1、logx日志处理1.1、logx简介1.2、日志初始化与配置1.3、常用方法1.4、配合defer

springboot加载不到nacos配置中心的配置问题处理

《springboot加载不到nacos配置中心的配置问题处理》:本文主要介绍springboot加载不到nacos配置中心的配置问题处理,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录springboot加载不到nacos配置中心的配置两种可能Spring Boot 版本Nacos

使用Python实现base64字符串与图片互转的详细步骤

《使用Python实现base64字符串与图片互转的详细步骤》要将一个Base64编码的字符串转换为图片文件并保存下来,可以使用Python的base64模块来实现,这一过程包括解码Base64字符串... 目录1. 图片编码为 Base64 字符串2. Base64 字符串解码为图片文件3. 示例使用注意

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化: