B - Kleene Inversion Editorial /

Time Limit: 2 sec / Memory Limit: 1024 MB

配点 : 300300

問題文

長さ NN の整数列 A = A0, A1, ..., AN1A~=~A_0,~A_1,~...,~A_{N - 1} があります。

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

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

ここで BB の転倒数は、整数の順序対 (i, j) (0i<jK×N1)(i,~j)~(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 で割った余りを出力せよ。


入力例 1Copy

Copy
2 2
2 1

出力例 1Copy

Copy
3

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

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

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


入力例 2Copy

Copy
3 5
1 1 1

出力例 2Copy

Copy
0

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


入力例 3Copy

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

出力例 3Copy

Copy
185297239

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

Score : 300300 points

Problem Statement

We have a sequence of NN integers A = A0, A1, ..., AN1A~=~A_0,~A_1,~...,~A_{N - 1}.

Let BB be a sequence of K×NK \times N integers obtained by concatenating KK copies of AA. For example, if A = 1, 3, 2A~=~1,~3,~2 and K = 2K~=~2, B = 1, 3, 2, 1, 3, 2B~=~1,~3,~2,~1,~3,~2.

Find the inversion number of BB, modulo 109+710^9 + 7.

Here the inversion number of BB is defined as the number of ordered pairs of integers (i, j) (0i<jK×N1)(i,~j)~(0 \leq i < j \leq K \times N - 1) such that Bi>BjB_i > B_j.

Constraints

  • All values in input are integers.
  • 1N20001 \leq N \leq 2000
  • 1K1091 \leq K \leq 10^9
  • 1Ai20001 \leq A_i \leq 2000

Input

Input is given from Standard Input in the following format:

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

Output

Print the inversion number of BB, modulo 109+710^9 + 7.


Sample Input 1Copy

Copy
2 2
2 1

Sample Output 1Copy

Copy
3

In this case, B = 2, 1, 2, 1B~=~2,~1,~2,~1. We have:

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

Thus, the inversion number of BB is 33.


Sample Input 2Copy

Copy
3 5
1 1 1

Sample Output 2Copy

Copy
0

AA may contain multiple occurrences of the same number.


Sample Input 3Copy

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

Sample Output 3Copy

Copy
185297239

Be sure to print the output modulo 109+710^9 + 7.



2025-04-23 (Wed)
05:05:28 +00:00