Skip to main content

FenwickTree

Struct FenwickTree 

Source
pub struct FenwickTree { /* private fields */ }
Expand description

Fenwick tree (Binary Indexed Tree) for prefix sum queries over u32 values.

Designed for virtualized list height layout: each entry i stores the height of item i, and prefix(i) gives the y-offset of item i+1.

Implementations§

Source§

impl FenwickTree

Source

pub fn new(n: usize) -> Self

Create a Fenwick tree of size n initialised to all zeros.

Source

pub fn from_values(values: &[u32]) -> Self

Create a Fenwick tree from an initial array of values in O(n).

This is faster than calling update n times (which would be O(n log n)).

Source

pub fn len(&self) -> usize

Number of elements.

Source

pub fn is_empty(&self) -> bool

Whether the tree is empty.

Source

pub fn update(&mut self, i: usize, delta: i32)

Add delta to element at position i (0-indexed). O(log n), zero alloc.

§Panics

Panics if i >= n.

Source

pub fn set(&mut self, i: usize, value: u32)

Set element at position i to value (0-indexed). O(log n).

Source

pub fn get(&self, i: usize) -> u32

Get the value at position i (0-indexed). O(log n).

Computed as prefix(i) - prefix(i-1).

Source

pub fn prefix(&self, i: usize) -> u32

Prefix sum of elements [0..=i] (0-indexed). O(log n), zero alloc.

§Panics

Panics if i >= n.

Source

pub fn range(&self, left: usize, right: usize) -> u32

Range sum of elements [left..=right] (0-indexed). O(log n).

§Panics

Panics if left > right or right >= n.

Source

pub fn total(&self) -> u32

Total sum of all elements. O(log n).

Source

pub fn batch_update(&mut self, deltas: &[(usize, i32)])

Apply multiple updates in a single pass. O(m log n), zero alloc.

Each (index, delta) pair is applied sequentially. This produces identical results to calling update for each pair individually.

Source

pub fn rebuild(&mut self, values: &[u32])

Rebuild the tree from a fresh array of values in O(n).

Requires values.len() == self.n.

§Panics

Panics if values.len() != self.n.

Source

pub fn find_prefix(&self, target: u32) -> Option<usize>

Find the largest index i such that prefix(i) <= target.

Returns None if all prefix sums exceed target (i.e., values[0] > target). This is useful for binary-search-by-offset in virtualized lists. O(log n), zero alloc.

Source

pub fn resize(&mut self, new_n: usize)

Resize the tree. If growing, new elements are initialised to 0. If shrinking, excess elements are dropped. O(new_n).

Trait Implementations§

Source§

impl Clone for FenwickTree

Source§

fn clone(&self) -> FenwickTree

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for FenwickTree

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more