【poj】2481 Cows【线段树单点更新】

原创 2016年05月31日 23:25:24

题意:

有N头牛 每头牛有一个[S,E]值 要求找出所有牛j使得Si <=Sjand Ej <= Ei and Ei - Si > Ej - Sj 对每头牛输出这样的牛的个数

题解:

先对所有牛按左端点为第一关键字升序右端点第二关键字降序排序,线段树内存右端点的值,然后每次query的是query当前节点的右端点到N的线段树和,这题还有一个就是去重,如果后一个和前一个一摸一样就直接把前面一个答案copy过来就好

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define lson l,mid,rt<<1
#define rson mid+1,r,rt<<1|1
const int N=1e5+5;
struct COW
{
    int st,ed,id;
    COW(){}
    COW(int a,int b,int c){st=a;ed=b;id=c;}
    bool operator<(const COW &b)const
    {return st<b.st||(st==b.st&&ed>b.ed);}
}cow[N];
int res[N],n,tree[N<<2],a,b;
void update(int pos,int l,int r,int rt)
{
    tree[rt]++;
    if(l==r)return;
    int mid=(l+r)>>1;
    if(pos<=mid)update(pos,lson);
    else update(pos,rson);
}
int query(int L,int R,int l,int r,int rt)
{
    if(L<=l&&r<=R)return tree[rt];
    int mid=(l+r)>>1,sum=0;
    if(L<=mid) sum+=query(L,R,lson);
    if(R>=mid) sum+=query(L,R,rson);
    return sum;
}
int main()
{
    while(scanf("%d",&n)&&n){
        for(int i=0;i<n;i++){
            scanf("%d%d",&a,&b);
            cow[i]=COW(a,b,i);
        }
        sort(cow,cow+n);
        memset(tree,0,sizeof(tree));
        for(int i=0;i<n;i++){
            if(i&&cow[i].st==cow[i-1].st&&cow[i].ed==cow[i-1].ed)
                res[cow[i].id]=res[cow[i-1].id];
            else res[cow[i].id]=query(cow[i].ed,N,0,N,1);
            update(cow[i].ed,0,N,1);
        }
        for(int i=0;i<n;i++)printf("%d%c",res[i],i==n-1?'\n':' ');
    }
    return 0;
}



版权声明:本文为博主原创文章,未经博主允许不得转载。

POJ 2481——Cows(树状数组)

Cows Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 12694   Accepted...
  • u014141559
  • u014141559
  • 2014年08月27日 19:44
  • 371

poj 2481 Cows【线段树单点更新】

Cows Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 19652   Accepted...
  • Archger
  • Archger
  • 2017年08月07日 20:39
  • 139

POJ 2481 - Cows 树状数组离线处理

题意:                       给了N个线段(N=l && R-L > r-l...               题解:                        这题就...
  • kk303
  • kk303
  • 2013年10月04日 18:16
  • 805

poj 2481 Cows(树状数组)

题目链接:点击打开链接 题意:给定一群牛和他们
  • Baoli1008
  • Baoli1008
  • 2014年09月01日 09:33
  • 290

POJ 2481 Cows(线段树[单点更新])

POJ 2481 Cows(线段树[单点更新])
  • queuelovestack
  • queuelovestack
  • 2015年10月23日 11:41
  • 361

POJ - 2481 Cows(线段树单点更新)

题意: 两个区间:[Si, Ei] 和 [Sj, Ej] (0
  • HelloWorld10086
  • HelloWorld10086
  • 2015年03月26日 19:48
  • 320

poj 2481 Cows 树状数组解法,详细解析。

Farmer John's cows have discovered that the clover growing along the ridge of the hill (which we can...
  • Lionel_D
  • Lionel_D
  • 2015年02月05日 19:30
  • 1141

poj 2481 Cows(线段树)

poj 2481 Cows
  • fallenfall
  • fallenfall
  • 2014年07月03日 11:27
  • 297

poj 2481 Cows 线段树

题目 Cows Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 19518 Accepted: 6...
  • yskyskyer123
  • yskyskyer123
  • 2017年07月29日 12:07
  • 98

POJ 2481 Cows 线段树

POJ 2481 Cows
  • NNDXNM
  • NNDXNM
  • 2015年04月08日 20:50
  • 323
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:【poj】2481 Cows【线段树单点更新】
举报原因:
原因补充:

(最多只允许输入30个字)