1394 Minimum Inversion Number

题目链接

http://acm.hdu.edu.cn/showproblem.php?pid=1394

Inversion Number, 树状数组

题目解释

对于一个由n个数字组成的序列,把它的队首m(0<=m<n)个元素移到队尾,求形成了另一个队列

长度为n的序列通过这种方式可以得到n种不同的序列,求这n个序列中逆序数最小的序列的逆序数

算法

关于树状数组

参考《树状数组》

由树状数组求原始数组的逆序对

对原始序列中的所有元素,其元素值+1(因为树状数组不能处理0,所有必须保证要处理的序列中没有值为0的元素)

对原始序列中的元素,从队尾至队首,依次对每个元素做以下操作:

1.把该元素q加入到树状数组a中,即a.modify(q, 1)

2.计算在q之前加入到a且比q小的元素个数,即ret = getsum(i - 1)

3.该序列的逆序对数 += ret

当序列中的元素全部处理完,就能计算出该序列的逆序对数了

依次求各种序列的逆序对数

令f(m)为把原始序列s的前m个元素移到队尾得到的序列的逆序对数

现在已求出f(0)

第一个元素q移到队尾后,f(1)=f(0)+比q大的元素个数-比q小的元素个数

依次类推,f(m) = f(m-1) + 比s[m-1]大的元素个数 - 比s[m-1]小的元素个数

这样就可以依次计算出所有序列的逆序对数了

代码

Last updated