#ATagc030d. [AGC030D] Inversion Sum

[AGC030D] Inversion Sum

题目描述

给定一个长度为 NN 的整数序列 A1,A2,,ANA_1,A_2,\ldots,A_N。你需要依次进行 QQ 次操作。第 ii 次操作由两个整数 Xi,YiX_i,Y_i 给出,你可以从以下两种操作中恰好选择一种执行:

  • 交换 AXiA_{X_i}AYiA_{Y_i} 的值;
  • 什么都不做。

所有操作的执行方式共有 2Q2^Q 种。请你求出对于所有可能的操作方式,最终得到的序列的逆序对数之和,并对 109+710^9+7 取模。

其中,序列 P1,P2,,PMP_1,P_2,\ldots,P_M 的逆序对数定义为满足 1i<jM1\leq i<j\leq MPi>PjP_i>P_j 的整数对 (i,j)(i,j) 的个数。

输入格式

输入从标准输入读入,格式如下:

NN QQ
A1A_1 A2A_2 \ldots ANA_N
X1X_1 Y1Y_1
\vdots
XQX_Q YQY_Q

输出格式

输出所有可能的最终序列的逆序对数之和对 109+710^9+7 取模的结果。

样例 1

输入

3 2
1
2
3
1 2
1 3

输出

6

样例 2

输入

5 3
3
2
3
1
4
1 5
2 3
4 2

输出

36

样例 3

输入

9 5
3
1
4
1
5
9
2
6
5
3 5
8 9
7 9
3 2
3 8

输出

425

说明/提示

限制条件

  • 1N30001\leq N\leq 3000
  • 0Q30000\leq Q\leq 3000
  • 0Ai109 (1iN)0\leq A_i\leq 10^9\ (1\leq i\leq N)
  • 1Xi,YiN (1iQ)1\leq X_i,Y_i\leq N\ (1\leq i\leq Q)
  • XiYi (1iQ)X_i\neq Y_i\ (1\leq i\leq Q)
  • 输入均为整数

样例说明 1

所有可能的操作方式如下,共有 44 种:

  • 11 次和第 22 次都什么都不做。最终序列为 1,2,31,2,3,逆序对数为 00
  • 11 次什么都不做,第 22 次交换。最终序列为 3,2,13,2,1,逆序对数为 33
  • 11 次交换,第 22 次什么都不做。最终序列为 2,1,32,1,3,逆序对数为 11
  • 11 次和第 22 次都交换。最终序列为 3,1,23,1,2,逆序对数为 22

这几种情况下逆序对数之和为 0+3+1+2=60+3+1+2=6,输出 66

由 ChatGPT 4.1 翻译