atcoder#MSOLUTIONS2019E. Product of Arithmetic Progression

Product of Arithmetic Progression

配点 : 600600

問題文

以下のような、nn 項からなる等差数列を考えます。

  • x,x+d,x+2d,,x+(n1)dx, x + d, x + 2d, \ldots, x + (n-1)d

この数列のすべての項の積はいくつでしょうか? その積を 1,000,0031,000,003 で割った余りを計算してください。

この形式の問いが QQ 個与えられます。 ii 個目の問いでは、x=xi,d=di,n=nix = x_i, d = d_i, n = n_i の場合の答えを計算してください。

制約

  • 1Q1051 \leq Q \leq 10^5
  • 0xi,di1,000,0020 \leq x_i, d_i \leq 1,000,002
  • 1ni1091 \leq n_i \leq 10^9
  • 入力中の値はすべて整数である。

入力

入力は以下の形式で標準入力から与えられる。

QQ

x1x_1 d1d_1 n1n_1

::

xQx_Q dQd_Q nQn_Q

出力

QQ 行出力せよ。

ii 行目に、ii 個目の問いに対する答えを出力せよ。

2
7 2 4
12345 67890 2019
9009
916936

最初のクエリに対し、答えは 7×9×11×13=90097 \times 9 \times 11 \times 13 = 9009 です。 積を 1,000,0031,000,003 で割った余りを求めることをお忘れなく。