atcoder#JSC2019QUALB. Kleene Inversion

Kleene Inversion

配点 : 300300

問題文

長さ NN の整数列 $A \sim = \sim A_0, \sim A_1, \sim ..., \sim A_{N - 1}$ があります。

AAKK 回繰り返した長さ K×NK \times N の整数列を BB とします。たとえば A=1,3,2A \sim = \sim 1, \sim 3, \sim 2K=2K \sim = \sim 2 のとき、 $B \sim = \sim 1, \sim 3, \sim 2, \sim 1, \sim 3, \sim 2$ です。

BB の転倒数を 109+710^9 + 7 で割った余りを求めてください。

ここで BB の転倒数は、整数の順序対 $(i, \sim j) \sim (0 \leq i < j \leq K \times N - 1)$ であって Bi>BjB_i > B_j を満たすものの個数として定義されます。

制約

  • 入力は全て整数である。
  • 1N20001 \leq N \leq 2000
  • 1K1091 \leq K \leq 10^9
  • 1Ai20001 \leq A_i \leq 2000

入力

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

NN KK

A0A_0 A1A_1 ...... AN1A_{N - 1}

出力

BB の転倒数を 109+710^9 + 7 で割った余りを出力せよ。

2 2
2 1
3

このケースでは B=2,1,2,1B \sim = \sim 2, \sim 1, \sim 2, \sim 1 です。

  • B0>B1B_0 > B_1
  • B0>B3B_0 > B_3
  • B2>B3B_2 > B_3

であり、BB の転倒数は 33 です。

3 5
1 1 1
0

AA は同じ数を複数含むこともあります。

10 998244353
10 9 8 7 5 6 3 4 2 1
185297239

109+710^9 + 7 で割った余りを出力することに注意してください。