struct FloorSum<R, const X: usize, const Y: usize>where
R: SemiRing,{
_marker: PhantomData<fn() -> R>,
}Fields§
§_marker: PhantomData<fn() -> R>Implementations§
Source§impl<R, const X: usize, const Y: usize> FloorSum<R, X, Y>where
R: SemiRing,
impl<R, const X: usize, const Y: usize> FloorSum<R, X, Y>where
R: SemiRing,
Sourcefn to_x() -> FloorSumData<R, X, Y>
fn to_x() -> FloorSumData<R, X, Y>
Examples found in repository?
crates/competitive/src/math/floor_sum.rs (line 289)
278pub fn floor_sum_polynomial<T, const X: usize, const Y: usize>(
279 n: u64,
280 a: u64,
281 b: u64,
282 m: u64,
283) -> [[T; Y]; X]
284where
285 T: Clone + Zero + One + Add<Output = T> + Mul<Output = T>,
286{
287 debug_assert!(a == 0 || n < (u64::MAX - b) / a);
288 floor_monoid_product::<FloorSum<AddMulOperation<T>, X, Y>>(
289 FloorSum::<AddMulOperation<T>, X, Y>::to_x(),
290 FloorSum::<AddMulOperation<T>, X, Y>::to_y(),
291 n,
292 a,
293 b,
294 m,
295 )
296 .dp
297}
298
299/// $$\sum_{i=l}^{r-1}i^X\left\lfloor\frac{a\times i+b}{m}\right\rfloor^Y$$
300pub fn floor_sum_polynomial_i64<T, const X: usize, const Y: usize>(
301 l: i64,
302 r: i64,
303 a: i64,
304 b: i64,
305 m: u64,
306) -> [[T; Y]; X]
307where
308 T: Clone + Zero + One + Add<Output = T> + Mul<Output = T>,
309 AddMulOperation<T>: SemiRing<T = T, Additive: Invertible>,
310{
311 assert!(l <= r);
312 assert!(m > 0);
313
314 if a < 0 {
315 let mut ans = floor_sum_polynomial_i64::<T, X, Y>(-r + 1, -l + 1, -a, b, m);
316 for ans in ans.iter_mut().skip(1).step_by(2) {
317 for ans in ans.iter_mut() {
318 *ans = AddMulOperation::<T>::neg(ans);
319 }
320 }
321 return ans;
322 }
323
324 let add_x = l;
325 let n = (r - l) as u64;
326 let b = a * add_x + b;
327
328 let add_y = b.div_euclid(m as i64);
329 let b = b.rem_euclid(m as i64);
330 assert!(a >= 0);
331 assert!(b >= 0);
332 let data = floor_monoid_product::<FloorSum<AddMulOperation<T>, X, Y>>(
333 FloorSum::<AddMulOperation<T>, X, Y>::to_x(),
334 FloorSum::<AddMulOperation<T>, X, Y>::to_y(),
335 n,
336 a as u64,
337 b as u64,
338 m,
339 );
340
341 let offset = FloorSum::<AddMulOperation<T>, X, Y>::offset(add_x, add_y);
342 FloorSum::<AddMulOperation<T>, X, Y>::operate(&offset, &data).dp
343}Sourcefn to_y() -> FloorSumData<R, X, Y>
fn to_y() -> FloorSumData<R, X, Y>
Examples found in repository?
crates/competitive/src/math/floor_sum.rs (line 290)
278pub fn floor_sum_polynomial<T, const X: usize, const Y: usize>(
279 n: u64,
280 a: u64,
281 b: u64,
282 m: u64,
283) -> [[T; Y]; X]
284where
285 T: Clone + Zero + One + Add<Output = T> + Mul<Output = T>,
286{
287 debug_assert!(a == 0 || n < (u64::MAX - b) / a);
288 floor_monoid_product::<FloorSum<AddMulOperation<T>, X, Y>>(
289 FloorSum::<AddMulOperation<T>, X, Y>::to_x(),
290 FloorSum::<AddMulOperation<T>, X, Y>::to_y(),
291 n,
292 a,
293 b,
294 m,
295 )
296 .dp
297}
298
299/// $$\sum_{i=l}^{r-1}i^X\left\lfloor\frac{a\times i+b}{m}\right\rfloor^Y$$
300pub fn floor_sum_polynomial_i64<T, const X: usize, const Y: usize>(
301 l: i64,
302 r: i64,
303 a: i64,
304 b: i64,
305 m: u64,
306) -> [[T; Y]; X]
307where
308 T: Clone + Zero + One + Add<Output = T> + Mul<Output = T>,
309 AddMulOperation<T>: SemiRing<T = T, Additive: Invertible>,
310{
311 assert!(l <= r);
312 assert!(m > 0);
313
314 if a < 0 {
315 let mut ans = floor_sum_polynomial_i64::<T, X, Y>(-r + 1, -l + 1, -a, b, m);
316 for ans in ans.iter_mut().skip(1).step_by(2) {
317 for ans in ans.iter_mut() {
318 *ans = AddMulOperation::<T>::neg(ans);
319 }
320 }
321 return ans;
322 }
323
324 let add_x = l;
325 let n = (r - l) as u64;
326 let b = a * add_x + b;
327
328 let add_y = b.div_euclid(m as i64);
329 let b = b.rem_euclid(m as i64);
330 assert!(a >= 0);
331 assert!(b >= 0);
332 let data = floor_monoid_product::<FloorSum<AddMulOperation<T>, X, Y>>(
333 FloorSum::<AddMulOperation<T>, X, Y>::to_x(),
334 FloorSum::<AddMulOperation<T>, X, Y>::to_y(),
335 n,
336 a as u64,
337 b as u64,
338 m,
339 );
340
341 let offset = FloorSum::<AddMulOperation<T>, X, Y>::offset(add_x, add_y);
342 FloorSum::<AddMulOperation<T>, X, Y>::operate(&offset, &data).dp
343}Source§impl<R, const X: usize, const Y: usize> FloorSum<R, X, Y>where
R: Ring<Additive: Invertible>,
impl<R, const X: usize, const Y: usize> FloorSum<R, X, Y>where
R: Ring<Additive: Invertible>,
Sourcefn offset(x: i64, y: i64) -> FloorSumData<R, X, Y>
fn offset(x: i64, y: i64) -> FloorSumData<R, X, Y>
Examples found in repository?
crates/competitive/src/math/floor_sum.rs (line 341)
300pub fn floor_sum_polynomial_i64<T, const X: usize, const Y: usize>(
301 l: i64,
302 r: i64,
303 a: i64,
304 b: i64,
305 m: u64,
306) -> [[T; Y]; X]
307where
308 T: Clone + Zero + One + Add<Output = T> + Mul<Output = T>,
309 AddMulOperation<T>: SemiRing<T = T, Additive: Invertible>,
310{
311 assert!(l <= r);
312 assert!(m > 0);
313
314 if a < 0 {
315 let mut ans = floor_sum_polynomial_i64::<T, X, Y>(-r + 1, -l + 1, -a, b, m);
316 for ans in ans.iter_mut().skip(1).step_by(2) {
317 for ans in ans.iter_mut() {
318 *ans = AddMulOperation::<T>::neg(ans);
319 }
320 }
321 return ans;
322 }
323
324 let add_x = l;
325 let n = (r - l) as u64;
326 let b = a * add_x + b;
327
328 let add_y = b.div_euclid(m as i64);
329 let b = b.rem_euclid(m as i64);
330 assert!(a >= 0);
331 assert!(b >= 0);
332 let data = floor_monoid_product::<FloorSum<AddMulOperation<T>, X, Y>>(
333 FloorSum::<AddMulOperation<T>, X, Y>::to_x(),
334 FloorSum::<AddMulOperation<T>, X, Y>::to_y(),
335 n,
336 a as u64,
337 b as u64,
338 m,
339 );
340
341 let offset = FloorSum::<AddMulOperation<T>, X, Y>::offset(add_x, add_y);
342 FloorSum::<AddMulOperation<T>, X, Y>::operate(&offset, &data).dp
343}Trait Implementations§
impl<R, const X: usize, const Y: usize> Associative for FloorSum<R, X, Y>where
R: SemiRing,
Auto Trait Implementations§
impl<R, const X: usize, const Y: usize> Freeze for FloorSum<R, X, Y>
impl<R, const X: usize, const Y: usize> RefUnwindSafe for FloorSum<R, X, Y>
impl<R, const X: usize, const Y: usize> Send for FloorSum<R, X, Y>
impl<R, const X: usize, const Y: usize> Sync for FloorSum<R, X, Y>
impl<R, const X: usize, const Y: usize> Unpin for FloorSum<R, X, Y>
impl<R, const X: usize, const Y: usize> UnwindSafe for FloorSum<R, X, Y>
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