zoukankan      html  css  js  c++  java
  • POJ 2528 Mayor's posters

    线段树成段替换+离散化

    /* ***********************************************
    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
    ",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
    ",ans);  
        }
        return 0;    
    }    
  • 相关阅读:
    删除表数据drop、truncate和delete的用法
    List,DataTable实现行转列的通用方案
    C#正则表达式简单限制输入11位手机号
    Oracle数据库byte存放汉字,9个汉字x3=27个字节
    SQL 语句
    $("p").fadeOut("fast")设置淡出效果
    神奇的 toLocaleString
    C#中精确计时的一点收获
    Web service stop after running serveral hours
    SQL Server中like匹配下划线的方法
  • 原文地址:https://www.cnblogs.com/zufezzt/p/4986515.html
Copyright © 2011-2022 走看看