首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

LintCode 线段树系列问题(线段树的构造,线段树的构造||,线段树的查询,线段树的查询II,线段树的修改)线段树的构造线段树的构造 II线段树的查询线段树查询 II线段树的修改

线段树(又称区间树), 是一种高级数据结构,他可以支持这样的一些操作: 查找给定的点包含在了哪些区间内 查找给定的区间包含了哪些点 线段树的构造 题目 线段树是一棵二叉树,他的每个节点包含了两个额外的属性...实现一个 build 方法,接受 start 和 end 作为参数, 然后构造一个代表区间 [start, end] 的线段树,返回这棵线段树的根。...样例 对于数组 [0, 空,2, 3], 对应的线段树为: ?...该方法将 root 为跟的线段树中 [start, end] = [index, index] 的节点修改为了新的 value ,并确保在修改后,线段树的每个节点的 max 属性仍然具有正确的值。...样例 对于线段树: ?

49330

线段

线段树 (有关线段树的定义来自LintCode网站的相关题目) 描述 线段树是一棵二叉树,他的每个节点包含了两个额外的属性start和end用于表示该节点所代表的区间。...说明 线段树(又称区间树), 是一种高级数据结构,他可以支持这样的一些操作: 查找给定的点包含在了哪些区间内 查找给定的区间包含了哪些点 样例 比如给定start=1, end=6,对应的线段树为:...最大线段树 纯粹的线段树并不能应用于太多的实际问题,一般来说线段树的节点除了start和end之外,还会有一个额外的属性值,我们以最大线段树为例,最大线段树的每一个节点还有一个代表区间中最大值的max...线段树的修改方法modify,接受三个参数root、index和value。...该方法将root为根的线段树中 [start,end] = [index,index] 的节点修改为了新的value,并确保在修改后,线段树的每个节点的max属性仍然具有正确的值。

3.8K91
您找到你想要的搜索结果了吗?
是的
没有找到

图解线段

线段树 ----   线段树是算法竞赛中常用的用来维护 区间信息 的数据结构。线段树可以在 O(\log_{2}{N}) 的时间复杂度内实现单点修改、区间修改、区间查询等操作。...线段树的基本结构 ---- 为数组(假设下标从 1 开始): a[5] = [{1,2,3,4,5}] 构造线段树如下图(采用堆式存储): 上述数组 D 用来保存线段树,由于采用的是堆式存储...线段树的建立 由于树树递归定义的,因此其建立也是递归的: void buildST(int left, int right, int p, vector& D, vector &...mid, p*2, D, a); build(mid+1, right, p*2+1, D, a); D[p] = D[p * 2] + D[p * 2 + 1]; } ---- 线段树的区间查询...---- 区间和: // [left,right] 为待查区间,[cl,cr] 为当前区间,p 为当前节点编号,D 为线段树的存储数组 int getSum(int left, int right

54530

什么是 “线段树” ?

线段树的概念 线段树,英文名称是Segment Tree,其本质也是一个二叉搜索树,区别在于线段树的每一个节点记录的都是一个区间,每个区间都被平均分为2个子区间,作为它的左右儿子。...线段树主要适用于某些相对罕见的应用场景: 比如给定了若干元素,要求统计出不同区间范围内,元素的个数。 现在我们已经知道了什么是线段树,那么看一个利用线段树的例子。...在学习线段树的概念的时候,我们就知道线段树的每个节点都存储了一个区间。比如说对于[1,10]这个节点,也就是这棵线段树的根节点,那么它的值为1+5+1+3+4+2+0+9+0+9=34。...思考与探究 下面让我们进行一些对于线段树的思考与探究: 【思考 1】 线段树都应用于什么环境?除了区间和外,能否解决更多问题?比起别的树有什么优势? 【答案 1】 线段树一般多用于区间问题。...另外就是线段树比起别的树的特点。线段树属于二叉搜索树,像我们熟悉的红黑树、AVL树其实也都属于二叉搜索树。只不过不同的二叉搜索树用处不相同。线段树比起别的树,它的最大特点就是用作存储区间的特性。

1.4K40

线段树(区间树)

当我们使用线段树来处理这类问题时,时间复杂度为O(logn),其执行效率就要比数组实现快很多。 什么是线段树?   ...线段树一定是满二叉树吗?不一定,这里是因为8恰好是2的三次方,刚好可以构成一颗满二叉树。   根节点代表整个线段,左孩子代表根节点线段的前半段,右孩子就是根节点线段的后半段。...如果现在数组中有十个元素,相应的线段树就不是二叉树了,如下: 注意:线段树不是完全二叉树,但线段树是平衡二叉树,当然堆也是平衡二叉树。...,但由于线段树是平衡二叉树,所以我们在处理时,是将线段树作为满二叉树在进行处理,满二叉树又是特殊的完全二叉树,所以线段树也可以使用数组来表示,线段树使用数组表示时,其索引与节点的关系如下: //...本文讲的是一维线段树,当然还有二维线段树和三维线段树,本文就不做介绍了,你们有兴趣可以去网上查阅相关资料进行学习。

11410

线段树入门总结

线段树的入门级 总结       线段树是一种二叉搜索树,与区间树相似,它将一个区间划分成一些单元区间,每个单元区间对应线段树中的一个叶结点。       ...对于线段树中的每一个非叶子节点[a,b],它的左儿子表示的区间为[a,(a+b)/2],右儿子表示的区间为[(a+b)/2+1,b]。...因此线段树是平衡二叉树,最后的子节点数目为N,即整个线段区间的长度。       使用线段树可以快速的查找某一个节点在若干条线段中出现的次数,时间复杂度为O(logN)。...【创建线段树(初始化)】:        由于线段树是用二叉树结构储存的,而且是近乎完全二叉树的,所以在这里我使用了数组来代替链表上图中区间上面的红色数字表示了结构体数组中对应的下标。...1 void BuildTree(int i,int left,int right){ // 为区间[left,right]建立一个以i为祖先的线段树,i为数组下标,我称作结点序号 2 node

95060

线段树详解分析

什么是线段树? 是用来存放给定区间(segment, or interval)内对应信息的一种数据结构。...对应于树状数组,线段树进行更新(update)的操作为O(logn),进行区间查询(range query)的操作也为O(logn)。...线段树是用一个完全二叉树来存储对应于其每一个区间(segment)的数据。该二叉树的每一个结点中保存着相对应于这一个区间的信息。...同时,线段树所使用的这个二叉树是用一个数组保存的,与堆(Heap)的实现方式相同。 线段树的作用? 线段树可以使用log(n) 的时间复杂度来进行更新和查询数组范围的和。...构建线段线段树在初始化时可以创建4倍原数组大小的空间 static class SegmentTree { int[] tree; int N = 100;

55810
领券