zoukankan      html  css  js  c++  java
  • POJ2299 Ultra-QuickSort

    传送门

    树状数组求逆序对 + 离散化?

    我好像永远都记不住怎么用树状数组求逆序对……以前我记得都是正着写的,这次怎么得倒着写才能过……

    然后本题a的范围极大,但是n的范围不大,500000,需要先手离散化一波,之后就可以正常按照树状数组操作了。然后在query的时候注意要-1.

    我们来看一下代码。

    #include<iostream>
    #include<cstdio>
    #include<cmath>
    #include<algorithm>
    #include<queue>
    #include<cstring>
    #include<utility>
    #include<map>
    #define pr pair<int,int>
    #define mp make_pair
    #define fi first
    #define sc second
    #define rep(i,a,n) for(int i = a;i <= n;i++)
    #define per(i,n,a) for(int i = n;i >= a;i--)
    #define enter putchar('
    ')
    #define lowbit(x) x & (-x)
    using namespace std;
    typedef long long ll;
    const int M = 500005;
    const int N = 32005;
    
    int read()
    {
        int ans = 0,op = 1;
        char ch = getchar();
        while(ch < '0' || ch > '9')
        {
        if(ch == '-') op = -1;
        ch = getchar();
        }
        while(ch >='0' && ch <= '9')
        {
        ans *= 10;
        ans += ch - '0';
        ch = getchar();
        }
        return ans * op;
    }
    
    int n,a[M],c[M],tot,d[M];
    ll ans;
    
    void add(int x)
    {
        while(x <= M-5) a[x]++,x += lowbit(x);
    }
    
    int query(int x)
    {
        int cur = 0;
        while(x) cur += a[x],x -= lowbit(x);
        return cur;
    }
    
    void clear()
    {
        tot = ans = 0;
        memset(a,0,sizeof(a));
    }
    
    int main()
    {
        while(1)
        {
        n = read();
        if(n == 0) break;
        clear();
        rep(i,1,n) c[i] = read(),d[i] = c[i];
        sort(c+1,c+1+n);
        tot = unique(c+1,c+1+n) - c - 1;
        per(i,n,1)
        {
            int k = lower_bound(c+1,c+1+tot,d[i]) - c;
            //printf("#%d
    ",k);
            ans += query(k-1),add(k);
        }
        printf("%lld
    ",ans);
        }
        return 0;
    }
  • 相关阅读:
    hypermesh生成MNF柔性体
    手机拍照参数的调整
    周金涛生前20篇雄文精华,一文尽览
    什么是DA控制
    win7系统程序未响应怎么办
    如何在老惠普电脑上安装windows xp系统
    linux的学习在runoob.com网站
    K:红黑树
    K:图的存储结构
    Q:链表的倒数第K个元素
  • 原文地址:https://www.cnblogs.com/captain1/p/9795367.html
Copyright © 2011-2022 走看看