Struct SlopeTrick

Source
pub struct SlopeTrick { /* private fields */ }

Implementations§

Source§

impl SlopeTrick

Source

pub fn new() -> Self

Create empty

Source

pub fn valley(a: i64, n: usize) -> Self

Create valley

f(x) = max(n(x-a), n(a-x))

Source

pub fn minimum(&self) -> i64

min f(x)

Source

pub fn min_range(&self) -> (Option<i64>, Option<i64>)

argmin_x f(x)

Source

pub fn add_const(&mut self, a: i64)

f(x) += a

Source

pub fn add_ramp(&mut self, a: i64)

f(x) += max(0, (x-a))

Examples found in repository?
crates/competitive/src/data_structure/slope_trick.rs (line 73)
72    pub fn add_abs(&mut self, a: i64) {
73        self.add_ramp(a);
74        self.add_pmar(a);
75    }
Source

pub fn add_pmar(&mut self, a: i64)

f(x) += max(0, (a-x))

Examples found in repository?
crates/competitive/src/data_structure/slope_trick.rs (line 74)
72    pub fn add_abs(&mut self, a: i64) {
73        self.add_ramp(a);
74        self.add_pmar(a);
75    }
Source

pub fn add_abs(&mut self, a: i64)

f(x) += |x-a|

Source

pub fn clear_left(&mut self)

right to left accumulated minimum

f’(x) := min f(y) (y >= x)

Source

pub fn clear_right(&mut self)

left to right accumulated minimum

f’(x) := min f(y) (y <= x)

Source

pub fn shift(&mut self, a: i64)

f’(x) := f(x-a)

Source

pub fn slide_minimum(&mut self, a: i64, b: i64)

f’(x) := min f(y) (x-a <= y <= x-b)

Examples found in repository?
crates/competitive/src/data_structure/slope_trick.rs (line 92)
91    pub fn shift(&mut self, a: i64) {
92        self.slide_minimum(a, a);
93    }

Trait Implementations§

Source§

impl Clone for SlopeTrick

Source§

fn clone(&self) -> SlopeTrick

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 SlopeTrick

Source§

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

Formats the value using the given formatter. Read more
Source§

impl Default for SlopeTrick

Source§

fn default() -> SlopeTrick

Returns the “default value” for a type. 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, 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.