[−][src]Struct amadeus_streaming::Sort
This data structure tracks the n
top values given a stream. It uses only O(n)
space.
Implementations
impl<T, F> Sort<T, F>
[src]
pub fn new(cmp: F, n: usize) -> Self
[src]
Create an empty Sort
data structure with the specified n
capacity.
pub fn capacity(&self) -> usize
[src]
The n
top elements we have capacity to track.
pub fn len(&self) -> usize
[src]
The number of elements currently held.
pub fn is_empty(&self) -> bool
[src]
If .len() == 0
pub fn clear(&mut self)
[src]
Clears the Sort
data structure, as if it was new.
pub fn iter(&self) -> Iter<'_, T>
[src]
An iterator visiting all elements in ascending order. The iterator element type is &'_ T
.
impl<T, F> Sort<T, F> where
F: Fn(&T, &T) -> Ordering,
[src]
F: Fn(&T, &T) -> Ordering,
Trait Implementations
impl<T, F> Add<Sort<T, F>> for Sort<T, F> where
F: Fn(&T, &T) -> Ordering,
[src]
F: Fn(&T, &T) -> Ordering,
type Output = Self
The resulting type after applying the +
operator.
fn add(self, other: Self) -> Self
[src]
impl<T, F> AddAssign<Sort<T, F>> for Sort<T, F> where
F: Fn(&T, &T) -> Ordering,
[src]
F: Fn(&T, &T) -> Ordering,
fn add_assign(&mut self, other: Self)
[src]
impl<T: Clone, F: Clone> Clone for Sort<T, F>
[src]
impl<T, F> Debug for Sort<T, F> where
T: Debug,
[src]
T: Debug,
impl<'de, T, F> Deserialize<'de> for Sort<T, F> where
T: Deserialize<'de>,
F: Deserialize<'de> + for<'a> Fn<(&'a T, &'a T), Output = Ordering>,
[src]
T: Deserialize<'de>,
F: Deserialize<'de> + for<'a> Fn<(&'a T, &'a T), Output = Ordering>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error> where
__D: Deserializer<'de>,
[src]
__D: Deserializer<'de>,
impl<T, F> IntoIterator for Sort<T, F>
[src]
type Item = T
The type of the elements being iterated over.
type IntoIter = IntoIter<T>
Which kind of iterator are we turning this into?
fn into_iter(self) -> Self::IntoIter
[src]
impl<T, F> Serialize for Sort<T, F> where
T: Serialize,
F: Serialize + for<'a> Fn<(&'a T, &'a T), Output = Ordering>,
[src]
T: Serialize,
F: Serialize + for<'a> Fn<(&'a T, &'a T), Output = Ordering>,
fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error> where
__S: Serializer,
[src]
__S: Serializer,
impl<T, F> Sum<Sort<T, F>> for Option<Sort<T, F>> where
F: Fn(&T, &T) -> Ordering,
[src]
F: Fn(&T, &T) -> Ordering,
Auto Trait Implementations
impl<T, F> RefUnwindSafe for Sort<T, F> where
F: RefUnwindSafe,
T: RefUnwindSafe,
F: RefUnwindSafe,
T: RefUnwindSafe,
impl<T, F> Send for Sort<T, F> where
F: Send,
T: Send,
F: Send,
T: Send,
impl<T, F> Sync for Sort<T, F> where
F: Sync,
T: Sync,
F: Sync,
T: Sync,
impl<T, F> Unpin for Sort<T, F> where
F: Unpin,
T: Unpin,
F: Unpin,
T: Unpin,
impl<T, F> UnwindSafe for Sort<T, F> where
F: UnwindSafe,
T: RefUnwindSafe + UnwindSafe,
F: UnwindSafe,
T: RefUnwindSafe + UnwindSafe,
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> DeserializeOwned for T where
T: for<'de> Deserialize<'de>,
[src]
T: for<'de> Deserialize<'de>,
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<I> IntoIterator for I where
I: Iterator,
[src]
I: Iterator,
type Item = <I as Iterator>::Item
The type of the elements being iterated over.
type IntoIter = I
Which kind of iterator are we turning this into?
fn into_iter(self) -> I
[src]
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
fn to_owned(&self) -> T
[src]
fn clone_into(&self, target: &mut T)
[src]
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
V: MultiLane<T>,