PrimePowerBinomial

Struct PrimePowerBinomial 

Source
struct PrimePowerBinomial {
    p: u64,
    e: u32,
    m: u64,
    size: usize,
    fact: Vec<u64>,
    inv_fact: Vec<u64>,
    delta: u64,
    bp: BarrettReduction<u64>,
    bm: BarrettReduction<u64>,
    bm128: BarrettReduction<u128>,
}

Fields§

§p: u64§e: u32§m: u64§size: usize§fact: Vec<u64>§inv_fact: Vec<u64>§delta: u64§bp: BarrettReduction<u64>§bm: BarrettReduction<u64>§bm128: BarrettReduction<u128>

Implementations§

Source§

impl PrimePowerBinomial

Source

fn new(p: u64, e: u32, max_n: u64) -> Self

Examples found in repository?
crates/competitive/src/math/arbitrary_mod_binomial.rs (line 217)
213    pub fn new(modulus: u64, max_n: u64) -> Self {
214        assert_ne!(modulus, 0);
215        let ppbs = prime_factors(modulus)
216            .into_iter()
217            .map(|(p, e)| PrimePowerBinomial::new(p, e, max_n))
218            .collect();
219        Self { ppbs }
220    }
Source

fn combination(&self, n: u64, k: u64) -> u64

Examples found in repository?
crates/competitive/src/math/arbitrary_mod_binomial.rs (line 226)
222    pub fn combination(&self, n: u64, k: u64) -> u64 {
223        solve_simultaneous_linear_congruence(
224            self.ppbs
225                .iter()
226                .map(|ppb| (1u64, ppb.combination(n, k), ppb.m)),
227        )
228        .unwrap()
229        .0
230    }

Trait Implementations§

Source§

impl Debug for PrimePowerBinomial

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> 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, 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.