继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

逆序数

holdtom
关注TA
已关注
手记 1885
粉丝 240
获赞 992


树状数组

void sol()

{

    for(int i=1;i<=n;++i) bs[i]=0;

    for(int i=1;i<=n;++i)

    scanf("%d",a+i),g[i]=a[i];

    sort(g+1,g+1+n);

    for(int i=1;i<=n;++i)

        a[i]=n+1-(lower_bound(g+1,g+1+n,a[i])-g);

    ll ans=0;

    for(int i=1;i<=n;++i)

    {

        for(int j=a[i]-1;j>=1;j-=j&-j) ans+=bs[j];

        for(int j=a[i];j<=n;j+=j&-j) ++bs[j];

    }

    printf("%lld\n",ans);

}

归并

const int N = 1010;

int a[N];

int c[N];

int cnt = 0;

void MergeSort(int l, int r)

{

    int mid, i, j, tmp;

    if (r > l + 1)

    {

        mid = (l + r) / 2;

        MergeSort(l, mid);

        MergeSort(mid, r);

        tmp = l;

        for (i = l, j = mid; i < mid && j < r;)

        {

            if (a[i] > a[j])

            {

                c[tmp++] = a[j++];

                cnt += mid - i;

            }

            else

            {

                c[tmp++] = a[i++];

            }

        }

        if (j < r)

        {

            for (; j < r; ++j)

            {

                c[tmp++] = a[j];

            }

        }

        else

        {

            for (; i < mid; ++i)

            {

                c[tmp++]=a[i];

            }

        }

        for (i = l; i < r; ++i)

        {

            a[i] = c[i];

        }

    }

    return ;

}

©著作权归作者所有:来自51CTO博客作者qinXpeng的原创作品,如需转载,请注明出处,否则将追究法律责任


打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP