• POJ-2299 Ultra-QuickSort(用树状数组求逆序对数)


    题目链接

    ac代码

    #include<iostream>
    #include<cstdio>
    #include<cstring>
    #include<algorithm>
    #include<bitset>
    #include<cassert>
    #include<cctype>
    #include<cmath>
    #include<cstdlib>
    #include<ctime>
    #include<deque>
    #include<iomanip>
    #include<list>
    #include<map>
    #include<queue>
    #include<set>
    #include<stack>
    #include<vector>
    #define mp make_pair
    #define pi acos(-1)
    #define pii pair<int, int>
    #define pll pair<long long , long long>
    #define ll long long
    #define ld long double
    #define MEMS(x) memset(x, -1, sizeof(x))
    #define MEM(x) memset(x, 0, sizeof(x))
    const int inf = 0x3f3f3f3f;
    const int maxn = 500001;
    using namespace std;
    int n;
    struct Intg
    {
        int data;
        int pos;
        bool operator<(const Intg num) const
        {
            return data < num.data;
        }
    }a[maxn];
    int p[maxn], d[maxn];
    int lowbit(int x)
    {
        return x & (-x);
    }
    void update(int x)
    {
        while(x <= maxn)
        {
            d[x]++;
            x += lowbit(x);
        }
    }
    int getsum(int x)
    {
        int ans = 0;
        while(x)    //一定写成这种形式,否则写成for循环形式会导致超时
        {
            ans += d[x];
            x -= lowbit(x);
        }
        return ans;
    }
    int main()
    {
    //    freopen("input.txt", "r", stdin);
    //    freopen("output.txt", "w", stdout);
        while(scanf("%d", &n) != EOF && n)
        {
            for(int i = 1; i <= n; i++)
            {
                scanf("%d", &a[i].data);
                a[i].pos = i;
            }
            sort(a + 1, a + n + 1);
            p[a[1].pos] = 1;
            int idx = 1;
            for(int i = 2; i <= n ; i++)
            {
                if(a[i].data == a[i-1].data)
                    p[a[i].pos] = idx;
                else
                    p[a[i].pos] = ++idx;
            }
            ll ans = 0;
            memset(d, 0, sizeof(d));
            for(int i = 1; i <= n; i++)
            {
                update(p[i]);
                ans += i - getsum(p[i]);
            }
            printf("%lld
    ", ans);
        }
    }
    
    
    
  • 相关阅读:
    如何选择自动化测试框架
    Android Crash 定位
    Tomcat 高性能实现关键点
    测试用例 自动生成工具PICT与AllPairs
    《活出生命的意义》节选
    java设计模式-Iterator
    java设计模式-State模式
    java设计模式-Command模式
    java设计模式-桥接模式
    小橘灯
  • 原文地址:https://www.cnblogs.com/KeepZ/p/12315307.html
Copyright © 2020-2023  润新知