首先应该对该【0,10000000】进行离散化

即先将点集进行排序,然后从小到大缩小其中的间距,使得最后点数不会超过2*n

然后就是线段树操作

只需进行染色,然后最后用nlgn进行一个个查询颜色记录即可

#include<cstdio>

#include<cstring>
int color[20005*4],a[20005],p[20005],l[10005],r[10005],pd[10005],i,j,k,n,t,length;
void qs(int x,int y){
    int i=x,j=y,k=a[(x+y)/2],t;
    do{
        while(a[i]<k) i++;
        while(a[j]>k) j--;
        if(i<=j){
            t=a[i];a[i]=a[j];a[j]=t;
            t=p[i];p[i]=p[j];p[j]=t;
            i++;j--;
        }
    }while(i<j);
    if(i<y) qs(i,y);
    if(x<j) qs(x,j);
}
void build(int x,int y,int rt){
    color[rt]=0;
    if(x>=y) return;
    int m=(x+y)/2;
    build(x,m,2*rt);
    build(m+1,y,2*rt+1);
}
void PushDown(int rt){
    if(color[rt]!=0){
        color[rt*2]=color[rt*2+1]=color[rt];
        color[rt]=0;
    }
}
void update(int x,int y,int rt){
    if(l[k]<=x&&r[k]>=y){
        color[rt]=k;
        return;
    }
    PushDown(rt);
    int m=(x+y)/2;
    if(l[k]<=m) update(x,m,rt*2);
    if(r[k]>m) update(m+1,y,rt*2+1);
}
int query(int x,int y,int rt){
    if(color[rt]!=0){
        if(!pd[color[rt]]) {
            pd[color[rt]]=1;
            return 1;
        }
        else return 0;
    }
    if(x==y) return 0;
    int m=(x+y)/2;
    return(query(x,m,rt*2)+query(m+1,y,rt*2+1));
}
int main()
{
    scanf("%d",&t);
    while(t--){
        memset(pd,0,sizeof(pd));
        scanf("%d",&n);
        for(i=1;i<=n;i++){
            scanf("%d%d",&a[2*i-1],&a[2*i]);
            p[2*i-1]=2*i-1;
            p[2*i]=2*i;
        }
        qs(1,2*n);
        length=1;
        for(i=1;i<=2*n;i++){
            if(p[i]%2==0)
                r[p[i]/2]=length;
            else
                l[(p[i]+1)/2]=length;
            if(a[i]!=a[i+1]) length++;
        }
        build(1,length,1);
        for(k=1;k<=n;k++)
            update(1,length,1);
        printf("%d\n",query(1,length,1));
    }
    return 0;
}

POJ2528 线段树的区间操作的更多相关文章

  1. poj-2528线段树练习

    title: poj-2528线段树练习 date: 2018-10-13 13:45:09 tags: acm 刷题 categories: ACM-线段树 概述 这道题坑了我好久啊啊啊啊,,,, ...

  2. Codeforces Round #222 (Div. 1) D. Developing Game 线段树有效区间合并

    D. Developing Game   Pavel is going to make a game of his dream. However, he knows that he can't mak ...

  3. hiho一下20周 线段树的区间修改

    线段树的区间修改 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 对于小Ho表现出的对线段树的理解,小Hi表示挺满意的,但是满意就够了么?于是小Hi将问题改了改,又出给了 ...

  4. hihoCode 1078 : 线段树的区间修改

    #1078 : 线段树的区间修改 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 对于小Ho表现出的对线段树的理解,小Hi表示挺满意的,但是满意就够了么?于是小Hi将问题 ...

  5. UVA 12436-Rip Van Winkle's Code(线段树的区间更新)

    题意: long long data[250001]; void A( int st, int nd ) { for( int i = st; i \le nd; i++ ) data[i] = da ...

  6. BZOJ 3110 ZJOI 2013 K大数查询 树套树(权值线段树套区间线段树)

    题目大意:有一些位置.这些位置上能够放若干个数字. 如今有两种操作. 1.在区间l到r上加入一个数字x 2.求出l到r上的第k大的数字是什么 思路:这样的题一看就是树套树,关键是怎么套,怎么写.(话说 ...

  7. hihoCoder #1078 : 线段树的区间修改(线段树区间更新板子题)

    #1078 : 线段树的区间修改 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 对于小Ho表现出的对线段树的理解,小Hi表示挺满意的,但是满意就够了么?于是小Hi将问题 ...

  8. 线段树(区间树)之区间染色和4n推导过程

    前言 线段树(区间树)是什么呢?有了二叉树.二分搜索树,线段树又是干什么的呢?最经典的线段树问题:区间染色:正如它的名字而言,主要解决区间的问题 一.线段树说明 1.什么是线段树? 线段树首先是二叉树 ...

  9. HDU 1698 just a hook 线段树,区间定值,求和

    Just a Hook Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1 ...

随机推荐

  1. aix 安装redis

    下载最新rpm安装包 http://www.perzl.org/aix/index.php?n=Main.Redis # uname -aAIX rhjf 1 6 00C5CC964C00# pwd/ ...

  2. Servlet实现web站点文件下载功能示例

    前段时间事情比较多,导致二月份没有记录自己的学习情况.最近接触了servlet,参考韩老师的教程自己写了一个web站点文件下载的小项目,该项目中还加入了简单的反盗链技术. 1.首先创建一个Shared ...

  3. ^M的前世今生

    ^M 是ascii中的'\r', 回车符,是16进制的0x0D,8进制的015,十进制的13. 回想计算机发展,旧的打字机使用两个字符来开始一个新行.首先是一个字符命令使打印头移回开始位置(回车),然 ...

  4. 【Cardboard】 体验 - Google Cardboard DIY及完成后简单体验

    体验 - Google Cardboard DIY及完成后简单体验 今年的Google I/O最让我感兴趣的除了Material Design以外就是这个Google Cardboard了.据说是Go ...

  5. 【BZOJ 1040】 [ZJOI2008]骑士

    Description Z国的骑士团是一个很有势力的组织,帮会中汇聚了来自各地的精英.他们劫富济贫,惩恶扬善,受到社会各界的赞扬.最近发生了一件可怕的事情,邪恶的Y国发动了一场针对Z国的侵略战争.战火 ...

  6. 【BZOJ1030】文本生成器

    Description JSOI交给队员ZYX一个任务,编制一个称之为“文本生成器”的电脑软件:该软件的使用者是一些低幼人群,他们现在使用的是GW文本生成器v6版.该软件可以随机生成一些文章―――总是 ...

  7. kissy使用注意事项

    使用kissy注意: 下载kissy压缩包后只需要拷贝build包到项目中即可, 样式自己写不用引用. 1.4.x引这个文件seed-min.js1.3.x引kissy-min.js

  8. MS Translator

    在看白老师的书的时候看到的,现在MS已经开始转向服务,真对不同行业具有不同的服务,有些免费的,还是十分值得我们借用的,毕竟是大公司出来的产品,都会保证SLA的. 不多说了,直接上地址: https:/ ...

  9. [转载]jquery tmpl使用方法

    动态请求数据来更新页面是现在非常常用的方法,比如博客评论的分页动态加载,微博的滚动加载和定时请求加载等. 这些情况下,动态请求返回的数据一般不是已拼好的 HTML 就是 JSON 或 XML,总之不在 ...

  10. 正确使用STL-MAP中Erase函数

    一切尽在代码中. #include <iostream> #include <map> #include <string> using namespace std ...