23得票6回答
在O(lg N)时间内查询一个范围内不同整数的数量,是否可能?

我已经阅读了一些关于两种常见数据结构的教程,它们可以在O(lg N)的时间内实现区间更新和查询:线段树和二叉索引树(BIT / Fenwick Tree)。 我找到的大多数示例都涉及到某些类似“范围内整数求和”、“范围内整数异或”等可交换和可结合运算。 我想知道这两个数据结构(或者任何其他数据...

9得票2回答
在C++中,用于线段树的STL

是否有适用于线段树的STL库? 在竞赛编程中,编写线段树代码需要花费大量时间。我想知道是否有适用于线段树的STL库,以便节省大量时间。

30得票4回答
树状数组与线段树的比较

我需要在一个数组的范围内计算总和,于是我了解了线段树和树状数组(Fenwick Tree),发现这两个数据结构都具有相同的渐进运行时间来查询和更新。我进行了更多的研究,发现这两个数据结构可以以相同的速度完成所有操作。两者都具有线性的内存使用(线段树的内存使用量是树状数组的两倍)。 除了运行时间...

8得票2回答
线段树空间要求

我在这篇HackerEarth的文章中发现,可以使用数组来实现分段树。对于位于数组索引为n的节点的子元素,在索引2n和2n+1的位置上。 此外,文章指出,要将n个元素存储在分段树中,需要2n+1个节点。 然而,最近当我解决与分段树相关的问题时,有时我的代码会出现运行时错误,当我将用于存储分...

9得票3回答
线段树的更新操作

我正在学习线段树,遇到了这个问题。 有一个数组 A 和两种操作类型 1. Find the Sum in Range L to R 2. Update the Element in Range L to R by Value X. 更新应该像这样。 A[L] = 1*X; A[L+...

14得票4回答
Java实现线段树

您知道在Java中实现(二进制)线段树的好方法吗?

14得票2回答
分段树中的数据映射和惰性传播

看起来整个互联网上只有一篇关于线段树中懒惰标记的好文章,它是:http://www.spoj.pl/forum/viewtopic.php?f=27&t=8296 我理解了只更新查询节点并标记其子节点的概念。但我的问题是,如果我先查询子节点,然后再查询父节点呢? 在这棵树中(还包括...

8得票2回答
在二维平面上拟合线段

我遇到了以下问题 给定一个大小为N x S的网格和m个与水平轴平行的线段(它们都是元组(x',x'',y)),回答Q个在线查询的形式为(x',x'')。这种查询的答案是最小的y(如果有的话),使得我们可以放置一条线段(x',x'',y)。所有线段都不重叠,但一个线段的开始可以是另一个线段的结...

32得票7回答
线段树数组的内存是多少?2 * 2 ^(ceil(log(n))) - 1。

该链接: http://www.geeksforgeeks.org/segment-tree-set-1-sum-of-given-range/。以下是引用的文本: 我们从一个段arr [0 ... n-1]开始。 每次我们将当前段分成两半(如果它尚未成为长度为1的段),然后在这两个部分上调...

242得票3回答
区间树、线段树、二叉索引树和范围树有哪些区别?

段树、区间树、二叉索引树和范围树在以下几个方面有何不同: 关键思想/定义 应用场景 性能/高维度顺序/空间消耗 请勿仅提供定义。