Struct nekolib::ds::BicrementalMedian
source · pub struct BicrementalMedian<T: Ord + Clone> { /* private fields */ }
Expand description
中央値の管理。
多重集合への要素の追加と削除を行いつつ、中央値を管理する。
Naming
incremental と decremental の双方向の処理を行うので、bidirectional の気持ちで bicremental とした。記憶が正しければえびちゃんの造語なので、 もっとよい名前があれば変えたい。dynamic は意味が曖昧なのできらい。
Notes
集合に $k$ 個追加・削除する操作をサポートできないか?と思ったが、 これだと計算量の保証ができない。$\{\{1, 2, \dots, n\}\}$ に対して $0$ を $n$ 個追加する操作と、$0$ を $n$ 個削除する操作を繰り返すことで、 簡単に worst $\Omega(n)$ 時間になってしまう。
Implementations§
Trait Implementations§
source§impl<T: Clone + Ord + Clone> Clone for BicrementalMedian<T>
impl<T: Clone + Ord + Clone> Clone for BicrementalMedian<T>
source§fn clone(&self) -> BicrementalMedian<T>
fn clone(&self) -> BicrementalMedian<T>
Returns a copy 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: PartialEq + Ord + Clone> PartialEq<BicrementalMedian<T>> for BicrementalMedian<T>
impl<T: PartialEq + Ord + Clone> PartialEq<BicrementalMedian<T>> for BicrementalMedian<T>
source§fn eq(&self, other: &BicrementalMedian<T>) -> bool
fn eq(&self, other: &BicrementalMedian<T>) -> bool
This method tests for
self
and other
values to be equal, and is used
by ==
.impl<T: Eq + Ord + Clone> Eq for BicrementalMedian<T>
impl<T: Ord + Clone> StructuralEq for BicrementalMedian<T>
impl<T: Ord + Clone> StructuralPartialEq for BicrementalMedian<T>
Auto Trait Implementations§
impl<T> RefUnwindSafe for BicrementalMedian<T>where T: RefUnwindSafe,
impl<T> Send for BicrementalMedian<T>where T: Send,
impl<T> Sync for BicrementalMedian<T>where T: Sync,
impl<T> Unpin for BicrementalMedian<T>
impl<T> UnwindSafe for BicrementalMedian<T>where T: RefUnwindSafe,
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