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

POJ 2528 Mayor's posters

时间:2015-11-22 20:28:15      阅读:133      评论:0      收藏:0      [点我收藏+]

标签:

线段树成段替换+离散化

/* ***********************************************
Author        :Zhou Zhentao
Email         :774388357@qq.com
Created Time  :2015/11/20 17:21:35
File Name     :acm.cpp
************************************************ */

#include <stdio.h>
#include <string.h>
#include <iostream>
#include <algorithm>
#include <vector>
#include <queue>
#include <set>
#include <map>
#include <string>
#include <math.h>
#include <stdlib.h>
#include <time.h>
using namespace std;

#define lson l , m , rt << 1    
#define rson m + 1 , r , rt << 1 | 1   
#define root 1 , N , 1   
#define LL long long    
const int maxn = 200000+10;    
LL add[maxn<<2];    
int x,tot,ans;
int q[maxn];
int li[maxn] , ri[maxn];  
int X[maxn*3];  
int flag[maxn];
int cnt; 

int Bin(int key,int n,int X[]) {  
    int l = 0 , r = n - 1;  
    while (l <= r) {  
        int m = (l + r) >> 1;  
        if (X[m] == key) return m;  
        if (X[m] < key) l = m + 1;  
        else r = m - 1;  
    }  
    return -1;  
}  
   
void PushDown(int rt) {    
    if (add[rt]) {    
        add[rt<<1] = add[rt];    
        add[rt<<1|1] = add[rt];    
        add[rt] = 0;    
    }    
}    
  
void update(int L,int R,int c,int l,int r,int rt) {    
    if (L <= l && r <= R) {    
        add[rt] = c;    
        return ;    
    }
    PushDown(rt);    
    int m = (l + r) >> 1; 
    if (L <= m) update(L , R , c , lson);    
    if (m < R) update(L , R , c , rson);    
}   

void Qu(int L,int R,int l,int r,int rt)
{
    if(add[rt]!=0)
    {
        if(!flag[add[rt]])
        {
            ans++;
            flag[add[rt]]=1;
        }
        return;
    }

    if(l==r) return;
//    PushDown(rt);
    int m = (l + r) >> 1;
    Qu(L , R , lson);
    Qu(L , R , rson);
}

int main()
{    
//    freopen("in.txt","r",stdin);
    int N,T;
    scanf("%d",&T);
     while(T--)
     {
        scanf("%d",&N);  
        int nn = 0;  
        for (int i = 0 ; i < N ; i ++) {  
            scanf("%d%d",&li[i] , &ri[i]);  
            X[nn++] = li[i];  
            X[nn++] = ri[i];  
        }  
        sort(X , X + nn);  
        int m = 1;  
        for (int i = 1 ; i < nn; i ++) {  
            if (X[i] != X[i-1]) X[m ++] = X[i];  
        }  
        for (int i = m - 1 ; i > 0 ; i --) {  
            if (X[i] != X[i-1] + 1) X[m ++] = X[i-1] + 1;  
        }  
        sort(X , X + m);  
        memset(add , 0 , sizeof(add));  
        for (int i = 0 ; i < N ; i ++) {  
            int l = Bin(li[i] , m , X);  
            int r = Bin(ri[i] , m , X); 
            l++;r++;
        //    printf("---- %d %d\n",l,r);
            update(l , r , i+1 ,1,m+1,1);  
        }  
        ans = 0;  
        memset(flag, 0 , sizeof(flag));  
        Qu(1,m,1 , m+1 , 1);  
        printf("%d\n",ans);  
    }
    return 0;    
}    

 

POJ 2528 Mayor's posters

标签:

原文地址:http://www.cnblogs.com/zufezzt/p/4986515.html

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