码迷,mamicode.com
首页 > 编程语言 > 详细

【BUAA 1246】数组中的逆序对

时间:2015-06-20 17:11:01      阅读:152      评论:0      收藏:0      [点我收藏+]

标签:归并   buaa   

数组中的逆序对

归并算法的灵活运用 之前就听学长说这个用来算逆序对很好用 一直没有自己实现过 这次虽然比赛中没去做 赛后自己实现了出来 很有成就感! 也对归并算法透彻领悟了 真的好多算法都需要理解 而不是死记硬背 之前就是硬背过的 过一段时间就忘光了 这次彻底明白了算法执行过程 比起做出这道题 更宝贵

代码如下

#include <bits/stdc++.h>
#define LL long long

using namespace std;

int num[111111];
int n[111111];
LL sum;

void Merge(int l,int m,int r)
{
    int bg1 = l,bg2 = m+1,ed1 = m,ed2 = r;
    int i,k;
    for(k = l;bg1 <= ed1 && bg2 <= ed2; ++k)
    {
        if(num[bg1] > num[bg2])
        {
            n[k] = num[bg2++];
            sum += m-bg1+1;
        }else n[k] = num[bg1++];
    }
    while(bg1 <= ed1) n[k++] = num[bg1++];
    while(bg2 <= ed2) n[k++] = num[bg2++];
    for(k = l; k <= r; ++k)
        num[k] = n[k];
}

void MSort(int l,int r)
{
    if(l < r)
    {
        int m = (l+r)/2;
        MSort(l,m);
        MSort(m+1,r);
        Merge(l,m,r);
    }
}

int main()
{
    int t,n,i;
    scanf("%d",&t);
    while(t--)
    {
        scanf("%d",&n);
        for(i = 0; i < n; ++i)
            scanf("%d",&num[i]);
        sum = 0;
        MSort(0,n-1);
        printf("%lld\n",sum);
    }
    return 0;
}

【BUAA 1246】数组中的逆序对

标签:归并   buaa   

原文地址:http://blog.csdn.net/challengerrumble/article/details/46573981

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!