- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
高级数据结构 by buaaGG 高级数据结构 线段树 树状数组 跳跃表 线段树 线段树英文名为Interval Tree,它是一种特殊的二叉树。 由于这里有很多大一的同学,首先我们先简单介绍一下树的概念,大二大三的同学就权当复习吧。 二叉树 如果限制树的一个节点最多有两个子节点(两个孩子),且这两个孩子是有顺序的,我们就称呼这样的树为二叉树。 二叉树的严格定义 二叉树是有限个节点的集合,这个集合或者为空,或者有一个根节点和两棵互不相交的成为左子树和右子树的二叉树组成。 二叉树的不是树! 二叉树和度为2的树是不同的。 度为2的树至少有一个节点的度为2,而二叉树没有这种要求。 度为2的树不区分左右子树,而二叉树是严格区分左右子树的。 二叉树的存储结构 顺序存储结构 链式存储结构 二叉树的顺序存储结构 二叉树的链式存储结构 线段树 下面我们在回到线段树,还记得他的英文名么——Interval Tree. Interval是区间的意思,这也是它与普通二叉数的区别。 什么区别呢?前面的介绍二叉树节点储存的都是某个值,而对于Interval Tree,节点储存的是一个区间(即区间的两个端点)。先看一个例子吧。 线段树 线段树的实现 顺序储存结构 线段树的建立 线段树的每个节点都表示一个区间[L, R] 对于一个线段树的区间: 若L R,则必能被分为[L, M]和[M+1, R],其中M = (L + R) / 2 若L = R,则为叶子节点。 如果用数组实现,节点T的左儿子是T * 2,代表[L, M]区间,右儿子是T * 2 + 1,代表[M+1, R]区间。 线段树的建立 void Build(int T, int L, int R){ if (L == R) { //Add values to the leave node; return; } int M = (L + R) / 2; Build(T*2, L, M); Build(T*2+1, M+1, R); //Update the current node with his left son and right son. } 查询某个区间 在[L, R]中查询[LL, RR]的时候有一下三种情况: [LL, RR]被[L, M]包含,此时直接在[L, M]中查询[LL, RR] [LL, RR]被[M+1, R]包含,此时直接在[M+1, R]中查询[LL, RR] [LL, RR]被M从中间截断,此时在[L, M]中查询[LL, M],在[M+1, R]中查询[M+1, RR],然后将两个查询得到的结果进行Update, 返回Update的结果。 这样递归处理就完成了查询。 查询某个区间 int Query(int T, int L, int R, int LL, int RR){ //如果需要返回多个结果,可以考虑返回一个struct if (LL == L RR == R){ return Tree[T]; } //这里添加滞后修改的代码 int M = (L + R) / 2; if (RR = M) return Query(T*2, L, M, LL, RR); if (LL M) return Query(T*2+1, M+1, R, LL, RR); int Left = Query(T*2, L, M, LL, M); int Right = Query(T*2+1, M+1, R, M+1, RR); return func(Left, Right); //计算返回值 } 修改某个区间 线段树的区间修改,是将某个区间[LL, RR](当LL == RR时退化为一个点)加上一个delta值,或者改变为一个cover值。 修改某个区间 在[L, R]中修改[LL, RR]有一下三种情况: [LL, RR]被[L, M]包含,此时直接在[L, M]中修改[LL, RR] [LL, RR]被[M+1, R]包含,此时直接在[M+1, R]中修改[LL, RR] [LL, RR]被M从中间截断,此时在[L, M]中修改[LL, M],在[M+1, R]中修改[M+1, RR]。 最后递归更新父节点。 修改某个区间 void Modify(int T, int L, int R, int LL, int RR, int Value){ if (LL == L RR == R){ //modify the n
您可能关注的文档
- 高二英语外研版必修5 module 2 A job worth doing read(精品·公开课件).ppt
- 高二英语上册unit10 warming up and reading(精品·公开课件).ppt
- 高二英语上册unit9 warming up and reading(精品·公开课件).ppt
- 高二英语外研版选修7Module5 Reading practice and Cul(精品·公开课件).ppt
- 高二英语五模块 三单元Unit3 Science versus nature课(精品·公开课件).ppt
- 高二英语下册Unit 22课件(精品·公开课件).ppt
- 高二英语下学期Unit11-15短语(精品·公开课件).ppt
- 高二英语下册Unit14课件 人教版(精品·公开课件).ppt
- 高二英语下学期unit15 Destination单词讲解(精品·公开课件).ppt
- 高二英语虚拟语气(精品·公开课件).ppt
- 2025四川天府银行社会招聘备考题库(攀枝花)含答案详解(最新).docx
- 2025四川银行首席信息官社会招聘备考题库及完整答案详解1套.docx
- 2025四川天府银行社会招聘备考题库(攀枝花)带答案详解.docx
- 2025四川天府银行社会招聘备考题库(成都)含答案详解(a卷).docx
- 2025四川广元市利州区选聘社区工作者50人备考题库及答案详解(基础+提升).docx
- 2025天津银行资产负债管理部总经理或副总经理招聘1人备考题库含答案详解(典型题).docx
- 2025四川天府银行社会招聘备考题库(西充)附答案详解(考试直接用).docx
- 2025年中国民生银行南宁分行招聘2人备考题库及答案详解(全优).docx
- 2025天津银行高级研究人才招聘备考题库附答案详解(达标题).docx
- 2025大连银行营口分行招聘2人备考题库及参考答案详解一套.docx
原创力文档


文档评论(0)