逆序对
题目描述
猫猫 TOM 和小老鼠 JERRY 最近又较量上了,但是毕竟都是成年人,他们已经不喜欢再玩那种你追我赶的游戏,现在他们喜欢玩统计。
最近,TOM 老猫查阅到一个人类称之为“逆序对”的东西,这东西是这样定义的:对于给定的一段正整数序列,逆序对就是序列中 $a_i>a_j$ 且 $i<j$ 的有序对。知道这概念后,他们就比赛谁先算出给定的一段正整数序列中逆序对的数目。注意序列中可能有重复数字。
**Update:数据已加强。**
输入输出格式
输入格式
第一行,一个数 $n$,表示序列中有 $n$ 个数。
第二行 $n$ 个数,表示给定的序列。序列中每个数字不超过 $10^9$。
输出格式
输出序列中逆序对的数目。
输入输出样例
输入样例 #1
6
5 4 2 6 3 1
输出样例 #1
11
说明
对于 $25\%$ 的数据,$n \leq 2500$。
对于 $50\%$ 的数据,$n \leq 4 \times 10^4$。
对于所有数据,$n \leq 5 \times 10^5$。
请使用较快的输入输出。
应该不会 $O(n^2)$ 过 50 万吧 by chen_zhe。