位置: 编程技术 - 正文

详解字典树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有鸭肉的意思吗)

  • 2021城建税
  • 盈利能力也可以反映短期偿债能力
  • 公司货款退款怎么写
  • 零税率和免税一样吗?哪一个更优惠?
  • 汽车购买者
  • 外币实收资本入账汇率
  • 折扣折让 红字发票账务处理
  • 补入库存商品的会计分录
  • 给员工发结婚礼金怎么说
  • 竞价服务费放在哪个会计科目?
  • 单位之间借款利息可以开票么
  • 销售中央空调并安装账务处理
  • 退货专票已经认证进项税怎么处理
  • 兼营免税业务,如何才能享受免税的优惠政策?
  • 什么是城镇土地使用税
  • 每个季度企业要缴纳什么税
  • 联营扣点怎么核算保本费用
  • 坏账准备的计提是什么意思
  • 施工单位临时设施的搭建费属于
  • 商业企业向供货方收取的返还收入
  • 鸿蒙负一屏怎么设置
  • 购买原材料折扣做什么会计科目
  • 批量删除 超链接
  • 代扣代缴代收代缴税款业务内容
  • 公司整体收购协议书范本
  • 一般纳税人转小规模流程
  • 收到员工罚款分录怎么记账
  • vue组件继承并重写属性方法
  • 在企业兼并时,被兼并企业价值评估的最适用假设是
  • 交暖气费可以开单位发票吗
  • php linux 环境搭建
  • php连接mysql数据库步骤正确的是
  • 库存现金账务处理案例
  • vuev-for循环k值的意义
  • 销售折扣购物卡怎么做账
  • 补交上年所得税怎么调表
  • 固定资产的主要风险和关键控制点有哪些?
  • 专项应付款 会计分录
  • 视同小规模纳税人是有?
  • 金蝶财务软件怎么冲销费用
  • 公司开发新产品时,由管理层任命的
  • 未完施工针对的是什么工程
  • 土地增值税要计入税金及附加吗
  • 以房抵债会计分录怎么做
  • 关于母子公司的关系的表述,正确的是( )
  • 营改增后建筑业怎么开票
  • 应收账款记账凭证怎么写
  • 开办费入哪个会计科目
  • 客户重复付款了怎么礼貌回复
  • 待摊费用在新会计准则里面有吗
  • 咨询服务费开票税率
  • sqlserver 查看表
  • mysql批量删除表sql
  • SQL Server2005、2008如何彻底删除卸载并重新安装?
  • win7系统怎么修复安装系统
  • xp系统如何清理缓存
  • freebsd怎么样
  • pe工具箱怎么用
  • firefox干啥的
  • linux系统中对新磁盘分区的命令
  • ctfmon.exe成功怎么解决
  • Win7系统启动盘
  • 电脑主板驱动
  • Win10预览版镜像
  • win8切换到桌面
  • Linux下OpenVPN配置静态密钥(static-key)验证教程
  • python语言如何获取随机整数
  • Unity3D游戏开发pdf
  • Node.js中的包管理工具是什么
  • wordpress单页面店铺
  • <2> unity3d 分包与上google play 之具体实战
  • unity3d知乎
  • 按钮点击后消失
  • win10下python
  • javascript模板
  • 置顶是怎么弄的
  • python怎么定义
  • 个人所得税是先交还是后交
  • 新旧动能转换是我们能否过坎的关键
  • 卫生志愿服务活动
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设