zoukankan      html  css  js  c++  java
  • POJ2352 star

    传送门

    这道题有个非常好听的名字,求二维偏序!

    听起来似乎很高端,但就是让求满足对于每个i,xi < xj && yi < yj的个数。

    这道题特别良心,给的顺序都是y递增,y相同x递增的,所以可以直接用树状数组维护x,当前的i答案个数就是query(x-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 = 100005;
    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],cnt,ans[M],x,y;
    
    void add(int x)
    {
        while(x <= N) a[x]++,x += lowbit(x);
    }
    
    int query(int x)
    {
        int cur = 0;
        while(x) cur += a[x],x -= lowbit(x);
        return cur;
    }
    
    int main()
    {
        n = read();
        rep(i,1,n)
        {
        x = read(),y = read(),x++;
        ans[query(x)]++;
        add(x);
        }
        rep(i,0,n-1) printf("%d
    ",ans[i]);
        return 0;
    }
  • 相关阅读:
    四则运算题目生成器
    个人博客作业Week1
    M1/M2项目阶段总结
    个人博客作业week7
    个人博客作业—2
    第一周个人博客作业
    关于生成四则运算式
    个人博客作业week7
    第二次博客作业
    关于webservice大数据量传输时的压缩和解压缩
  • 原文地址:https://www.cnblogs.com/captain1/p/9795386.html
Copyright © 2011-2022 走看看