数論的アルゴリズム詰め合わせです。
pow_mod(x:int, n:int, m:int):int
$x^n \bmod m$ を返します。
制約
計算量
inv_mod(x:int, m:int):int
$xy \equiv 1 \pmod m$ なる $y$ のうち、$0 \le y < m$ を満たすものを返します。
制約
計算量
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)$ を返します。
制約
ll
に収まる。計算量
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}}$ で等しい値を返します。
制約
計算量