| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> 可持久化trie树 -> 正文阅读 |
|
[数据结构与算法]可持久化trie树 |
https://blog.csdn.net/weixin_43959739/article/details/84922554 详情可以看这一篇,或者李煜东老师的书p253. 下面来介绍一下本人理解的 建立可持久化trie树的过程。 1.创建新版本的时候什么时候和之前版本的节点发生关系? 私以为,不妨以下图为例,具体来说,就是将当前版本与之前版本都从根节点出发,将当前版本该节点出发没有,之前版本有的一些信息进行连接,很好理解,因为最新版本相当于目前所有版本的总和 因此之前的信息就通过这种方式维护即可,那么问题来了,对于当前节点,那些都有的信息应该怎么进行处理呢?答案是,将之前版本与目前同时向下遍历,重复上述连接信息操作,便可以得到一颗信息完全的可持久化字典树了。(不妨自己画一下试试)。 3.对于最大异或和这题,注意s[0]需要insert 个 0,因为这样才能求出 l = 1, r = n 时候的最值。 2.该开辟多少空间 对于数位题,由于范围一般是 1e6左右,因此,开N * 24或者其他,可以保证空间需求。 3.时间问题 开辟的时间复杂度是总长度的线性函数。 4.对于空节点idx为什么要赋为-1 5.对持久化trie的每个节点额外维护一个信息version,表示其所属的持久化版本,显然一个节点的version等于其子节点中最大的版本号(因为子节点要么是连向之前的版本,要么创建了该节点后再创建子节点)。 ’ 例题
|
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/26 15:45:17- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |