逆序数:在一个排列中,如果一对数的前后位置与大小顺序相反,即前面的数大于后面的数,那么它们就称为一个逆序。这是百度百科里的定义。
如 4 7 6 8 5 1 3 2 逆序数为20 在我所了解中求逆序数有两种思路:一种是求出数列a[n]中排列在a[i]前面比a[i]大的数的个数,然后将n个数求和即为逆序数。另一种是求出数列a[n]中排列在a[i]后面比a[i]小的数的个数,然后将N个数求和。我运用的是第一种思路。
while(i<M&&j<N)
{
if(left[i]<right[j])
arr[t++]=left[i++];
else
{
count=count+M-i;
arr[t++]=right[j++];
}
}其余代码在我的另一篇文章写合并排序笔记中有,只有这一段不同,其他基本一样。要在外部定义一个全局变量count ,主函数里面记得要初始化count。因为每次调用之后count的值会保存上一次的。
因为right数组保存的是右边的,则如果left中如果有某个数比right中大,则计算当前这个数的逆序数
如:
4 7 6 8 5 1 3 2 先分 则 为 4
7 6 8 5 1 3 2 然后合并,4与7合并成4 7此时逆序数为0 。 6 8合并逆序数依然为0,5 和1 合并。5是存在left数组中,1存在right数组中,此时1小于5,此时逆序数加1.同理合并3和2,逆序数变为2;
然后将4 7和 6 8合并,left[]={4,7},right[]={6,8}left[1]>right[0]则,逆序数增量为2-1 。2表示的是left中数的个数,1表示的是7的位置。
依次类推。。。。。
本文介绍了逆序数的概念及如何利用合并排序算法计算一个序列的逆序数。通过具体的例子详细解释了算法的实现过程。
4585

被折叠的 条评论
为什么被折叠?



