Java中字典树的算法实现
发表于:2025-01-18 作者:千家信息网编辑
千家信息网最后更新 2025年01月18日,这篇文章主要讲解了"Java中字典树的算法实现",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"Java中字典树的算法实现"吧!前言字典树,又称单词查找树
千家信息网最后更新 2025年01月18日Java中字典树的算法实现
这篇文章主要讲解了"Java中字典树的算法实现",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"Java中字典树的算法实现"吧!
前言
字典树,又称单词查找树,是一个典型的 一对多的字符串匹配算法。"一"指的是一个模式串,"多"指的是多个模板串。字典树经常被用来统计、排序和保存大量的字符串。它利用字符串的公共前缀来减少查询时间,最大限度地减少无谓的字符串比较。
字典树有3个基本性质:
根节点不包含字符,其余的每个节点都包含一个字符;
从根节点到某一节点,路径上经过的字符连接起来,为该节点对应的字符串;
每个节点的所有子节点包含的字符都不相同。
pass
参数:代表从这个点经过的单词数量。root根即就是整棵树有多少单词。
end
参数: 代表在这个点结束的单词有几个。例如: 上图有两个 hello,在o结点的end参数就是2。
实现的基本功能: 增删查。
算法解析
首先是结点的参数:
public class Node { public int pass; public int end; public Node[] nexts; //下一个字母的地址 public Node() { pass = 0; end = 0; nexts = new Node[26]; //这里我们就以小写字母为例 }}
下面就是基本功能的实现:
import java.util.Scanner;public class Main { public static void main(String[] args) { String[] arr = {"hello", "hello"}; Trie root = new Trie(); for (int i = 0; i < arr.length; i++) { root.addWord(arr[i]); } //root.delWord("hello"); Scanner sc = new Scanner(System.in); String s = sc.nextLine(); if (root.searchWord(s) != 0) { System.out.println("该字典树有这个" + s + " 单词"); } } public static class Node { public int pass; public int end; public Node[] nexts; //下一个字母的地址 public Node() { pass = 0; end = 0; nexts = new Node[26]; } } public static class Trie { private Node root; public Trie() { root = new Node(); } //增加 public void addWord(String str) { char[] arr = str.toCharArray(); root.pass++; Node node = root; for (char s : arr) { int index = s - 'a'; //以相应的ASCII码值差值,进行数组的下标存储 if (node.nexts[index] == null) { node.nexts[index] = new Node(); } node = node.nexts[index]; node.pass++; //经过这个结点,pass就加1 } node.end++; } //删除 public void delWord(String str) { //删除之前,应该查询一下这颗树有没有这个单词 while (searchWord(str) != 0) { char[] arr = str.toCharArray(); Node node = root; node.pass--; for (int i = 0; i < str.length(); i++) { int index = arr[i] - 'a'; node = node.nexts[index]; node.pass--; } node.end--; } } //查找 public int searchWord(String str) { if (str == null) { return 0; } char[] arr = str.toCharArray(); Node node = root; for (int i = 0; i < str.length(); i++) { int index = arr[i] - 'a'; if (node.nexts[index] == null) { return 0; } node = node.nexts[index]; } return node.end; //返回最后那一个结点的end值即可 } }}
感谢各位的阅读,以上就是"Java中字典树的算法实现"的内容了,经过本文的学习后,相信大家对Java中字典树的算法实现这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!
字符
字典
节点
算法
单词
字符串
参数
就是
结点
字母
学习
代表
内容
功能
地址
查询
相同
上图
下标
两个
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
杭州什么都有网络技术公司
服务器设置虚拟内存有没有用
传奇登陆器与服务器不配套
画饭圈乱象会网络安全的绘画
计算机网络技术与计算机科学
一汽软件开发待遇
软件开发能开工作室吗
文明网络安全活动方案
义乌软件开发的工作
xgpu怎么切服务器
4g网络技术应用发展
做网站服务器要多少兆
实惠的销售管理软件开发企业
服务器文件上锁了
军营网络安全宣传月讨论
本地网页如何调用数据库数据
腾讯防沉迷网络安全平台
高一学生有哪些网络安全教育
机顶盒升级服务器失败
深信服服务器修改管理口ip
八年级上册政治网络安全手抄报
net软件开发的应用
2k22 登录不上服务器
黎明杀机pc服务器互通吗
河南综合软件开发报价表
4g网络技术应用发展
360手机网络安全设置
我国互联网科技公司劣势
数据库默认当前时间的语句
海曙嵌入式软件开发项目