pub struct SegmentTree<T> { /* private fields */ }Available on crate feature
monoid only.Expand description
SegmentTree is a data structure for efficient range queries based on perfect binary tree.
It requires the underlying operation on the data to form a Monoid.
§Examples
use semigroup::{op::Sum, segment_tree::SegmentTree};
let data = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
let mut sum_tree: SegmentTree<_> = data.into_iter().map(Sum).collect();
assert_eq!(sum_tree.fold(3..=5).0, 12);
sum_tree.update(4, 8.into());
assert_eq!(sum_tree.fold(3..=5).0, 16);Implementations§
Source§impl<T> SegmentTree<T>
impl<T> SegmentTree<T>
Source§impl<T> SegmentTree<T>
impl<T> SegmentTree<T>
Source§impl<T> SegmentTree<T>
impl<T> SegmentTree<T>
Source§impl<T: Monoid + Clone> SegmentTree<T>
impl<T: Monoid + Clone> SegmentTree<T>
Sourcepub fn update(&mut self, i: usize, x: T) -> Option<T>
pub fn update(&mut self, i: usize, x: T) -> Option<T>
O(log(n)), set leaf[i] = x, and update segment tree.
Sourcepub fn update_with<F>(&mut self, i: usize, f: F) -> Option<T>
pub fn update_with<F>(&mut self, i: usize, f: F) -> Option<T>
O(log(n)), update leaf[i] by f(leaf[i]), and update segment tree.
Sourcepub fn push(&mut self, x: T)
pub fn push(&mut self, x: T)
amortized O(log(n)), push x to the segment tree, when construct new segment tree should be used Self::from or Self::from_iter (std::iter::Iterator::collect) instead.
Sourcepub fn extend_from_slice(&mut self, slice: &[T])
pub fn extend_from_slice(&mut self, slice: &[T])
amortized O(len(slice) log(n)), extend segment tree by given slice.
Sourcepub fn fold<R>(&self, range: R) -> Twhere
R: RangeBounds<usize>,
pub fn fold<R>(&self, range: R) -> Twhere
R: RangeBounds<usize>,
O(log(n)), fold the range.
Sourcepub fn bisect_left<R, F>(&self, range: R, cmp: F) -> Option<usize>
pub fn bisect_left<R, F>(&self, range: R, cmp: F) -> Option<usize>
O(log^2(n)), search the leftmost leaf where cmp(x) is true in the range.
Sourcepub fn bisect_right<R, F>(&self, range: R, cmp: F) -> Option<usize>
pub fn bisect_right<R, F>(&self, range: R, cmp: F) -> Option<usize>
O(log^2(n)), search the rightmost leaf where cmp(x) is true in the range.
Trait Implementations§
Source§impl<T: Clone> Clone for SegmentTree<T>
impl<T: Clone> Clone for SegmentTree<T>
Source§fn clone(&self) -> SegmentTree<T>
fn clone(&self) -> SegmentTree<T>
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl<T: Debug> Debug for SegmentTree<T>
impl<T: Debug> Debug for SegmentTree<T>
Source§impl<T: Default> Default for SegmentTree<T>
impl<T: Default> Default for SegmentTree<T>
Source§fn default() -> SegmentTree<T>
fn default() -> SegmentTree<T>
Returns the “default value” for a type. Read more
Source§impl<T: Monoid + Clone> Extend<T> for SegmentTree<T>
impl<T: Monoid + Clone> Extend<T> for SegmentTree<T>
Source§fn extend<I: IntoIterator<Item = T>>(&mut self, iter: I)
fn extend<I: IntoIterator<Item = T>>(&mut self, iter: I)
Extends a collection with the contents of an iterator. Read more
Source§fn extend_one(&mut self, item: A)
fn extend_one(&mut self, item: A)
🔬This is a nightly-only experimental API. (
extend_one)Extends a collection with exactly one element.
Source§fn extend_reserve(&mut self, additional: usize)
fn extend_reserve(&mut self, additional: usize)
🔬This is a nightly-only experimental API. (
extend_one)Reserves capacity in a collection for the given number of additional elements. Read more
Source§impl<T: Monoid + Clone> FromIterator<T> for SegmentTree<T>
impl<T: Monoid + Clone> FromIterator<T> for SegmentTree<T>
Source§fn from_iter<I: IntoIterator<Item = T>>(iter: I) -> Self
fn from_iter<I: IntoIterator<Item = T>>(iter: I) -> Self
Creates a value from an iterator. Read more
Source§impl<T: Hash> Hash for SegmentTree<T>
impl<T: Hash> Hash for SegmentTree<T>
Source§impl<T, I: SegmentTreeIndex<T>> Index<I> for SegmentTree<T>
impl<T, I: SegmentTreeIndex<T>> Index<I> for SegmentTree<T>
Source§impl<'a, T> IntoIterator for &'a SegmentTree<T>
impl<'a, T> IntoIterator for &'a SegmentTree<T>
Source§impl<T> IntoIterator for SegmentTree<T>
impl<T> IntoIterator for SegmentTree<T>
Source§impl<T: PartialEq> PartialEq for SegmentTree<T>
impl<T: PartialEq> PartialEq for SegmentTree<T>
impl<T: Eq> Eq for SegmentTree<T>
impl<T> StructuralPartialEq for SegmentTree<T>
Auto Trait Implementations§
impl<T> Freeze for SegmentTree<T>
impl<T> RefUnwindSafe for SegmentTree<T>where
T: RefUnwindSafe,
impl<T> Send for SegmentTree<T>where
T: Send,
impl<T> Sync for SegmentTree<T>where
T: Sync,
impl<T> Unpin for SegmentTree<T>where
T: Unpin,
impl<T> UnwindSafe for SegmentTree<T>where
T: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more