码迷,mamicode.com
首页 > 其他好文 > 详细

D - Mayor's posters

时间:2018-02-24 21:54:10      阅读:226      评论:0      收藏:0      [点我收藏+]

标签:ble   enter   注意   特殊情况   错误   style   大于   struct   tps   

思路:线段树+离散化。
离散化时注意特殊情况,如果两个数相差大于一,离散时也应该差1。比如 1 3 离散后应该为 1 2。
错因:
1.二分时出现错误,,zz  zz  Orz
2. if(tree[now].l==tree[now].r)  return ; 这句话漏了。   Orz          还要注意这句话的位置。
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define M 10000010
#define MAXN 10010
using namespace std;
int t,n,m,tot,ans;
int x[MAXN],y[MAXN];
int pos[M],hash[MAXN*4];
struct nond{
    int l,r,flag;
}tree[MAXN*16];
void build(int now,int l,int r){
    tree[now].l=l;tree[now].r=r;
    if(tree[now].l==tree[now].r){
        tree[now].flag=0;return ;
    }
    int mid=(tree[now].l+tree[now].r)/2;
    build(now*2,l,mid);
    build(now*2+1,mid+1,r);
}
void down(int now){
    tree[now*2].flag=tree[now].flag;
    tree[now*2+1].flag=tree[now].flag;
    tree[now].flag=0;
}
void change(int now,int l,int r,int x){
    if(tree[now].l==l&&tree[now].r==r){
        tree[now].flag=x;
        return ;
    }
    if(tree[now].flag)    down(now);
    int mid=(tree[now].l+tree[now].r)/2;
    if(r<=mid)    change(now*2,l,r,x);
    else if(l>mid)    change(now*2+1,l,r,x);
    else{ change(now*2,l,mid,x);change(now*2+1,mid+1,r,x); }
}
void query(int now){
    if(tree[now].flag){
        if(!pos[tree[now].flag])    ans++;
        pos[tree[now].flag]=1;return ;
    }
    if(tree[now].l==tree[now].r)    return ;
    int mid=(tree[now].l+tree[now].r)/2;
    query(now*2);query(now*2+1);
}
int findhash(int now){
    int l=1,r=tot;
    while(l<=r){
        int mid=(l+r)/2;
        if(hash[mid]<now)    l=mid+1;
        else    r=mid-1;
    }
    return l;
}
int main(){
    scanf("%d",&t);
    while(t--){
        scanf("%d",&n);ans=0;
        for(int i=1;i<=n;i++){
            scanf("%d%d",&x[i],&y[i]);
            pos[++m]=x[i];pos[++m]=y[i];
        }
        sort(pos+1,pos+1+m);
        m=unique(pos+1,pos+1+m)-(pos+1);
        hash[++tot]=pos[1];
        for(int i=2;i<=m;i++){
            if(pos[i]-pos[i-1]>1)    hash[++tot]=pos[i-1]+1;
            hash[++tot]=pos[i];
        }
        memset(pos,0,sizeof(pos));
        build(1,1,tot);
        for(int i=1;i<=n;i++){
            int l=findhash(x[i]);
            int r=findhash(y[i]);
            change(1,l,r,i);
        }
        query(1);printf("%d\n",ans);
        m=0;tot=0;memset(pos,0,sizeof(pos));
    }
}

 

D - Mayor's posters

标签:ble   enter   注意   特殊情况   错误   style   大于   struct   tps   

原文地址:https://www.cnblogs.com/cangT-Tlan/p/8467616.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!