Math

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

pow_mod

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

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

制約

計算量

inv_mod

ll inv_mod(ll x, ll m)

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

制約

計算量

crt

pair<ll, ll> crt(vector<ll> r, vector<ll> m)

同じ長さの配列 $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

ll floor_sum(ll n, ll m, ll a, ll b)

$$\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

#include <atcoder/math> #include <cstdio> using namespace std; using namespace atcoder; int main() { int t; scanf("%d", &t); for (int i = 0; i < t; i++) { long long n, m, a, b; scanf("%lld %lld %lld %lld", &n, &m, &a, &b); printf("%lld\n", floor_sum(n, m, a, b)); } return 0; }