数据结构-非线性结构-树形结构: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

相关文章

一文教你Python如何快速精准抓取网页数据

《一文教你Python如何快速精准抓取网页数据》这篇文章主要为大家详细介绍了如何利用Python实现快速精准抓取网页数据,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录1. 准备工作2. 基础爬虫实现3. 高级功能扩展3.1 抓取文章详情3.2 保存数据到文件4. 完整示例

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

python处理带有时区的日期和时间数据

《python处理带有时区的日期和时间数据》这篇文章主要为大家详细介绍了如何在Python中使用pytz库处理时区信息,包括获取当前UTC时间,转换为特定时区等,有需要的小伙伴可以参考一下... 目录时区基本信息python datetime使用timezonepandas处理时区数据知识延展时区基本信息

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

SpringMVC 通过ajax 前后端数据交互的实现方法

《SpringMVC通过ajax前后端数据交互的实现方法》:本文主要介绍SpringMVC通过ajax前后端数据交互的实现方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价... 在前端的开发过程中,经常在html页面通过AJAX进行前后端数据的交互,SpringMVC的controll

Pandas统计每行数据中的空值的方法示例

《Pandas统计每行数据中的空值的方法示例》处理缺失数据(NaN值)是一个非常常见的问题,本文主要介绍了Pandas统计每行数据中的空值的方法示例,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是空值?为什么要统计空值?准备工作创建示例数据统计每行空值数量进一步分析www.chinasem.cn处

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读