POJ2352 star

Posted captain1

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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;
}

 

以上是关于POJ2352 star的主要内容,如果未能解决你的问题,请参考以下文章

[POJ2352] Stars(树状数组)

POJ2352 star

POJ——T2352 Stars

POJ 2352 Stars

POJ2352 Stars

poj 2352 Stars