位置: 编程技术 - 正文

详解字典树Trie结构及其Python代码实现(字典树原理)

编辑:rootadmin

推荐整理分享详解字典树Trie结构及其Python代码实现(字典树原理),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:字典树算法,字典树算法,字典树模板,字典树算法,字典树的作用,字典树的作用,什么是字典树,什么是字典树,内容如对您有帮助,希望把文章链接给更多的朋友!

字典树(Trie)可以保存一些字符串->值的对应关系。基本上,它跟 Java 的 HashMap 功能相同,都是 key-value 映射,只不过 Trie 的 key 只能是字符串。Trie 的强大之处就在于它的时间复杂度。它的插入和查询时间复杂度都为 O(k) ,其中 k 为 key 的长度,与 Trie 中保存了多少个元素无关。Hash 表号称是 O(1) 的,但在计算 hash 的时候就肯定会是 O(k) ,而且还有碰撞之类的问题;Trie 的缺点是空间消耗很高。至于Trie树的实现,可以用数组,也可以用指针动态分配,我做题时为了方便就用了数组,静态分配空间。Trie树,又称单词查找树或键树,是一种树形结构,是一种哈希树的变种。典型应用是用于统计和排序大量的字符串(但不仅限于字符串),所以经常被搜索引擎系统用于文本词频统计。它的优点是:最大限度地减少无谓的字符串比较,查询效率比哈希表高。Trie的核心思想是空间换时间。利用字符串的公共前缀来降低查询时间的开销以达到提高效率的目的。Trie树中每个单词都是通过character by character方法进行存储,相同前缀单词共享前缀节点.可以看到,每条路径组成一个单词.上面这颗树存了to/tea/ted/ten/inn这些词.

Trie树的基本性质可以归纳为: (1)根节点不包含字符,除根节点意外每个节点只包含一个字符。(2)从根节点到某一个节点,路径上经过的字符连接起来,为该节点对应的字符串。 (3)每个节点的所有子节点包含的字符串不相同。

详解字典树Trie结构及其Python代码实现(字典树原理)

性质(1)根节点不包含字符,除根节点外的每个节点只包含一个字符。(2)从根节点到某一个节点,路径上经过的字符连接起来,为该节点对应的字符串。(3)每个节点的所有子节点包含的字符串不相同。

基本思想(以字母树为例):1、插入过程对于一个单词,从根开始,沿着单词的各个字母所对应的树中的节点分支向下走,直到单词遍历完,将最后的节点标记为红色,表示该单词已插入Trie树。2、查询过程同样的,从根开始按照单词的字母顺序向下遍历trie树,一旦发现某个节点标记不存在或者单词遍历完成而最后的节点未标记为红色,则表示该单词不存在,若最后的节点标记为红色,表示该单词存在。

应用(1)词频统计比直接用hash节省空间(2)搜索提示输入前缀的时候提示可以构成的词(3)作为辅助结构如后缀树,AC自动机等的辅助结构

实现虽然Python没有指针,但是可以用嵌套字典来实现树结构.对于非ascii的单词,统一用unicode编码来插入与搜索.

详解duck typing鸭子类型程序设计与Python的实现示例 在程序设计中,鸭子类型(英语:ducktyping)是动态类型的一种风格。在这种风格中,一个对象有效的语义,不是由继承自特定的类或实现特定的接口,

Python的Django中将文件上传至七牛云存储的代码分享 最近在写的一个django小项目需要实现用户上传图片的功能,使用到了七牛云存储,特此记录下来。这里我使用的七牛pythonSDK版本是7.0.3,函数使用上可能

使用Python的Flask框架来搭建第一个Web应用程序 1、初始化在这章,你将学到Flask应用程序的不同部分。同时,你将编写和运行你的第一个Flaskweb应用程序。所有的Flask应用程序都必须创建一个应用程序

标签: 字典树原理

本文链接地址:https://www.jiuchutong.com/biancheng/386950.html 转载请保留说明!

上一篇:Python中利用Scipy包的SIFT方法进行图片识别的实例教程(python中scipy用法)

下一篇:详解duck typing鸭子类型程序设计与Python的实现示例(duck有鸭肉的意思吗)

  • 交通事故的支出是否可以个税税前扣除
  • 附加税计提多了怎么调整税额
  • 企业账户被冻结可以去开其他账户吗
  • 银行承兑贴现的会计分录怎么做
  • 个人开劳务发票怎么开
  • 现金预算包括哪些内容,来源是什么
  • 溢价发行可转换公司债券会计分录例题
  • 公司过桥贷款怎么贷
  • 公司之间有哪些关系
  • 购买办公家具合同
  • 不涉及税收
  • 房产税免收范围包括
  • 机动车类专用发票
  • 自然灾害造成的存货净损失计入什么科目
  • 缴纳社保需要什么东西
  • 幼儿园收的餐费必须与食谱做平账怎么调账
  • 扣收贷款本息
  • 海关票怎么认证
  • 政府高薪补贴
  • 专用发票右上角的数字表示什么
  • 零申报做账怎么做
  • 企业销售使用过的汽车如何开票
  • 个人股票期权收益所得税怎么缴纳?
  • 内部调拨账务处理
  • 租金怎么来计算个税
  • 此windows副本不是正版影响电脑使用吗
  • windows10 怎么样
  • 企业收到的政府补贴,怎么入账
  • 付款后收到发票怎么写摘要
  • php zip模块
  • 误删开始菜单
  • 戴尔电脑设置u盘
  • win10网络带宽
  • 收到服务费发票可以计入什么科目
  • php语法和常用的函数
  • 教学用具属于什么项目类别
  • 错误申报多交增值税已经扣税
  • canvas软件教程
  • 高温补贴入账科目
  • es6promise的理解
  • 修改公司章程注意事项
  • 临时工交押金会扣钱吗
  • 旅行社怎样进行营销
  • 人力资源公司代办
  • 帝国cms导入模板后怎样调用
  • 高新技术企业相关税收政策
  • 年终企业所得税怎么结转
  • 作废发票清单要回收吗
  • sqlserver判断数字
  • 计提附加税金额
  • 结转清理净损失怎么算
  • 为什么到期一次还本付息要用债权投资利息调整
  • MySql 5.6.36 64位绿色版安装图文教程
  • linux下mysql 5.7.16 免安装版本图文教程
  • 光盘安装系统怎么操作
  • xp系统分区工具
  • 借助竹子赞美人物气节的诗句有哪些
  • win8怎么玩帝国时代2
  • centos划分分区
  • win7打开网页显示证书有问题
  • Win10系统怎么截图快捷键
  • cocos2d-x教程
  • Access to the path "LibraryUnityAssembliesUnityEngine.xml" is denied.
  • unity3d ngui-TweenRotation翻牌动画
  • Ubuntu12.04(X86_64)上安装Mesa-8.0.4
  • javascript抢票
  • 基于重大误解实施的民事法律行为
  • shell脚本用法
  • unity获取物体的位置
  • Python快速从注释生成文档的方法
  • unity2d角色换装
  • js写日期
  • 税控开票软件里的汇总怎么弄
  • 北京国税电子税务局
  • 深圳税务局怎么添加办税员
  • 青霉素过敏是因为提纯不好吗
  • 税务总局电子申报软件怎么用
  • 车船税完税证明查询官网
  • 河北省税金费率
  • 营业税属于地方税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设