Math

数論的アルゴリズム詰め合わせです。

pow_mod

pow_mod(x:int, n:int, m:int):int

$x^n \bmod m$ を返します。

制約

計算量

inv_mod

inv_mod(x:int, m:int):int

$xy \equiv 1 \pmod m$ なる $y$ のうち、$0 \le y < m$ を満たすものを返します。

制約

計算量

crt

crt(r:seq[int], m:seq[int]):(int,int)

同じ長さの配列 $r, m$ を渡します。この配列の長さを $n$ とした時、

$$x \equiv r[i] \pmod{m[i]}, \forall i \in \lbrace 0,1,\cdots, n - 1 \rbrace$$

を解きます。答えは(存在するならば) $y, z (0 \leq y < z = \mathrm{lcm}(m[i]))$ を用いて $x \equiv y \pmod z$ の形で書けることが知られており、この $(y, z)$ をpairとして返します。答えがない場合は $(0, 0)$ を返します。$n=0$ の時は $(0, 1)$ を返します。

制約

計算量

floor_sum

floor_sum(n:int, m:int, a:int, b:int):int

$$\sum_{i = 0}^{n - 1} \left\lfloor \frac{a \times i + b}{m} \right\rfloor$$

を返します。答えがオーバーフローしたならば $\bmod 2^{\mathrm{64}}$ で等しい値を返します。

制約

計算量

使用例

AC code of https://atcoder.jp/contests/practice2/tasks/practice2_c

import atcoder/header import atcoder/math let t = nextInt() for i in 0..<t: let n, m, a, b = nextInt() echo floor_sum(n, m, a, b)