No.2896 Monotonic Prime Factors
タグ : / 解いたユーザー数 83
作問者 : loop0919 / テスター : hiro1729
問題文
正整数 $n, m$ に対して $f(n, m)$ を、次の条件をすべて満たす長さ $n$ の整数列 $a = (a_1, a_2, \cdots, a_n)$ の個数と定義します。
- $2 \le a_i$
- $\displaystyle \prod_{i = 1}^n a_i = m$
- $1 \le i < j \le N$ ならば、 $a_i$ の任意の素因数 $p$ と $a_j$ の任意の素因数 $q$ について $p \le q$ を満たす。
また正整数 $x$ があり、はじめ $x = 1$ です。
次のように説明されるクエリが $Q$ 個与えられるので、$k = 1, 2, \cdots, Q$ の順に処理してください。
素因数とは
$2$ 以上の整数 $n$ の素因数とは、次の条件をすべて満たす集合 $P = \{P_1, P_2, \cdots, P_{|P|}\}$ の要素を指します。
- $P_i$ は素数である。
- $i \ne j$ ならば $P_i \ne P_j$ である。
- 次の条件を満たす長さ $|P|$ の整数列 $E = (E_1, E_2, \cdots, E_{|P|})$ が存在する。
- $1 \le E_i$
- $\displaystyle \prod_{i = 1}^{|P|} P_i^{E_i} = n$
ここで、このような $P$ は一意に定まることが証明できます。
$\prod$(総積記号)とは
長さ $n ~ (1 \le n)$ の数列 $a = (a_1, a_2, \cdots, a_n)$ について $\displaystyle \prod_{i = 1}^n a_i$ とは、$a_1 \times a_2 \times \cdots \times a_n$ を指します。
入力
$Q$ $A_1$ $B_1$ $A_2$ $B_2$ $\vdots$ $A_Q$ $B_Q$
入力はすべて以下の制約を満たす。
- $1 \le Q \le 10^5$
- $2 \le A_k \le 10^5$
- $1 \le B_k \le 10^5$
- 入力はすべて整数である。
出力
$Q$ 行出力せよ。 $k$ 行目には $k$ 個目のクエリの答えを出力せよ。
サンプル
サンプル1
入力
3 12 2 15 3 7 7
出力
2 6 0
各クエリについて、次のことが言えます。
- $1$ 個目のクエリについて、
- $x$ を $1 \times 12 = 12$ に更新する。
- その後、 $f(2, 12)$ を計算する。条件を満たす整数列は $(2, 6), (4, 3)$ の $2$ 個である。理由は以下の通りである。
- $(2, 6)$ について、$2 = 2, ~ 6 = 2 \times 3$ である。すべての要素が $2$ 以上かつ総積が $12$ であり、かつ $2 \le 2, ~ 2 \le 3$ であるため条件を満たす。
- $(4, 3)$ について、$4 = 2^2, ~ 3 = 3$ である。すべての要素が $2$ 以上かつ総積が $12$ であり、かつ $2 \le 3$ であるため条件を満たす。
- $2$ 個目のクエリについて、
- $x$ を $12 \times 15 = 180$ に更新する。
- その後、 $f(3, 180)$ を計算する。条件を満たす整数列は $(2,2, 45), (2, 6, 15), (2, 18, 5), (4, 3, 15), (4, 9, 5), (12, 3, 5)$ の $6$ 個である。
- $3$ 個目のクエリついて、
- $x$ を $180 \times 7 = 1260$ に更新する。
- その後、$f(7, 1260)$ を計算する。条件を満たす整数列は存在しないため、 $0$ 個である。
サンプル2
入力
16 10 1 3465 13 121 4 2450 1 4620 3 2310 2 40425 7 245 13 11550 13 98 15 16940 3 20 13 9091 5 49 20 33 28 84 31415
出力
1 0 56 1 171 24 593775 354817320 916064377 951522724 1128 32537773 270725 913512504 802620790 0
各クエリの答えとして、$998244353$ で割った余りを出力することを忘れないでください。
提出するには、Twitter 、GitHub、 Googleもしくは右上の雲マークをクリックしてアカウントを作成してください。