手记

逆序数


树状数组

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的原创作品,如需转载,请注明出处,否则将追究法律责任


0人推荐
随时随地看视频
慕课网APP