`
king_tt
  • 浏览: 2099428 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Ural 1019 A Line painting(线段树,成段更新离散化)

 
阅读更多

链接:

http://acm.timus.ru/problem.aspx?space=1&num=1019


题目大意:

一条线段上有点0~10^9. 初始时全部都是白色。 然后会有一些操作:把【a b】区间染成白色,或者把【a,b】区间染成黑色。

最后,求最长的一段白色。


分析与总结:

线段树成段更新染色。当然,由于数据量小,也可以直接暴力。

1. 在离散化问题上卡了我很久,WA了很多次,主要是因为这个线段是的点是0~10^9,0和10^9这两点是必须要添加上去的。

2. 在最后扫描连续的白色区间时,要注意结尾边界


代码:

1. 线段树

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define STOP puts("Stop here~");
#define FF(i,n) for(int i=0; i<(n); ++i)
#define FOR(i,s,t) for(int i=(s); i<(t); ++i)
#define mid ((left+right)>>1)
#define lson rt<<1, left, m
#define rson rt<<1|1, m+1, right
const int MAXN = 100000;

int col[MAXN],arr[MAXN<<1];
int A[MAXN],B[MAXN];
char C[MAXN];
int vis[MAXN];


void update(int rt,int left,int right,int l,int r,int data){
    if(l<=left && right<=r){
        col[rt] = data;
        return;
    }
    if(col[rt] == data) return;
    if(col[rt] != -1){
        col[rt<<1] = col[rt<<1|1] = col[rt];
        col[rt] = -1;
    }
    int m = mid;
    if(l <= m) update(lson,l,r,data);
    if(r > m) update(rson,l,r,data);
}
void query(int rt,int left,int right){
    if(col[rt] >= 0){
        FOR(i,left,right+1) vis[i]=col[rt];
        return;
    }
    if(left!=right && col[rt]==-1){
        int m = mid;
        query(lson);
        query(rson);
    }
}

int binary(int left,int right,int x){
    while(left < right){
        int m = (left+right)>>1;
        if(arr[m] >= x) right=m;
        else left=m+1;
    }
    return left;
}
int main(){
    int n; char ch[3];
    while(~scanf("%d",&n)){
        int kk=0;
        arr[kk++] = 0;
        arr[kk++] = 1e9;
        FF(i,n){
            scanf("%d%d%s",&A[i],&B[i],ch);
            C[i] = ch[0];
            arr[kk++]=A[i]; arr[kk++]=B[i];
        }
        sort(arr,arr+kk);
        int end = kk;
        kk = 1;
        FOR(i,1,end){
            if(arr[i]!=arr[i-1])arr[kk++]=arr[i];
        }
        end = kk;
        FOR(i,1,end){
            if(arr[i]>arr[i-1]+1) arr[kk++]=arr[i-1]+1;
        }

        sort(arr,arr+kk);

        memset(col,-1,sizeof(col));
        col[1] = 0;

        FF(i,n){
            int a=binary(0,kk,A[i]);
            int b=binary(0,kk,B[i]);
            if(C[i]=='b'){
                update(1,1,kk-1,a+1,b,1);

            }
            else{
                update(1,1,kk-1,a+1,b,0);
            }
        }

        int i=1,maxx=-1,ans_x=0,ans_y=kk-1;

        query(1,1,kk-1);
        memcpy(col,vis,sizeof(vis));

        while(i<kk){
            if(col[i]==0){
                int j = i+1;
                while(col[j]==0 && j<kk)++j;
                --j;
                int ll=arr[j]-arr[i-1];
                if(ll > maxx){
                    maxx=ll;
                    ans_x=i-1; ans_y=j;
                }
                i = j;
            }
            ++i;
        }
        printf("%d %d\n",arr[ans_x], arr[ans_y]);
    }
    return 0;
}


2. 暴力

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define STOP puts("Stop here~");
#define FF(i,n) for(int i=0; i<(n); ++i)
#define FOR(i,s,t) for(int i=(s); i<(t); ++i)
const int MAXN = 100000;

int col[MAXN],arr[MAXN<<1];
int A[MAXN],B[MAXN];
char C[MAXN];

int binary(int left,int right,int x){
    while(left < right){
        int m = (left+right)>>1;
        if(arr[m] >= x) right=m;
        else left=m+1;
    }
    return left;
}
int main(){
    int n; char ch[3];
    while(~scanf("%d",&n)){
        int kk=0;
        arr[kk++] = 0;
        arr[kk++] = 1e9;
        FF(i,n){
            scanf("%d%d%s",&A[i],&B[i],ch);
            C[i] = ch[0];
            arr[kk++]=A[i]; arr[kk++]=B[i];
        }
        sort(arr,arr+kk);
        int end = kk;
        kk = 1;
        FOR(i,1,end){
            if(arr[i]!=arr[i-1])arr[kk++]=arr[i];
        }
        end = kk;
        FOR(i,1,end){
            if(arr[i]>arr[i-1]+1) arr[kk++]=arr[i-1]+1;
        }

        sort(arr,arr+kk);

        memset(col,0,sizeof(col));
        FF(i,n){
            int a=binary(0,kk,A[i]);
            int b=binary(0,kk,B[i]);
            if(C[i]=='b'){
                FOR(i,a+1,b+1)col[i]=1;
            }
            else{
                FOR(i,a+1,b+1)col[i]=0;
            }
        }

        int i=1,maxx=-1,ans_x=0,ans_y=kk-1;

        while(i<kk){
            if(col[i]==0){
                int j = i+1;
                while(col[j]==0 && j<kk)++j;
                --j;
                int ll=arr[j]-arr[i-1];
                if(ll > maxx){
                    maxx=ll;
                    ans_x=i-1; ans_y=j;
                }
                i = j;
            }
            ++i;
        }
        printf("%d %d\n",arr[ans_x], arr[ans_y]);
    }
    return 0;
}



—— 生命的意义,在于赋予它意义士。

原创http://blog.csdn.net/shuangde800By D_Double (转载请标明)




分享到:
评论

相关推荐

    线段树题目

    大量线段树题目 zoj 1610 线段覆盖 poj 2777 线段覆盖 poj 2528 需要离散化,建树不同,需要处理不同-&gt;注意这组数据 3 1 10 1 3 6 10 the ans is 3. hdu 1754 求区间最大值 hdu 1166 求区间和 hdu 1698 成段更新 ...

    Ural URAL 解题思路

    Ural解题思路 Ural解题思路 Ural解题思路 Ural解题思路

    Ural

    Ural

    URAL部分测试数据

    URAL(Timus Online Judge)部分测试数据 不全

    URAL3D

    URAL3D

    acm_ural_1148

    Pascal acm_timus_ural_1148.pas

    Ural 1238 源代码

    Ural 1238 源代码 涉及算法(动态规划、贪心、DFS)

    acm_ural_1099

    Pascal acm_timus_ural_1099.pas

    Ural ACM 1000源代码(c++)

    Ural ACM 1000源代码(c++),vc++6.0在XPsp2下编译通过,Timus Online Judge再线测评通过

    ural题解

    包含了ural题库中Vol_I 到Vol_III的所有题目的解题思路

    ural vol I 题解 by yuhch123 pdf

    ural 题解 yuhch123。 关于yuhch123: ioi2008 金牌第一名,这是当初它做ural 第一卷时的题解

    ural部分题解

    部分题解 大牛出品 Vol1-3 不是很全,约有200题左右

    URAL-PHA

    URAL-PHA

    hdu pku ural 题目分类

    因为大三了 不弄ACM了 所以这些就删了 删之前希望可以帮到别人

    Python库 | ural-0.28.0.tar.gz

    资源分类:Python库 所属语言:Python 资源全名:ural-0.28.0.tar.gz 资源来源:官方 安装方法:https://lanzao.blog.csdn.net/article/details/101784059

    Ural-开源

    基于张量类模板的线性代数C ++库,可用于表示等级0的张量,标量向量,1的向量,2的矩阵,3的等级3的张量等。它还包括BLAS和LAPACK子例程的接口。

    APIO2013课件

    1钱桥_提交答案题目的处理方法.pptx 2冯齐纬_URAL题目选讲 3曹钦翔_线段树应用.pptx 4李超_Problems in UralChampionship.pptx 5陈许旻_数论与AI

    ural

    乌拉尔

    PART II THE URAL-ALTAIC HYPOTHESIS CHAPTER IV. THE URAL-ALTAIC HYPOTHESIS AND TUNGUS MATERIAL (1931年)

    28. The Theoretical Background of the Ural-Altale Hypothesis The hypothesis of common origin of the Altaic languages,and even the Ural-Altaic languages,dates from the first half of the last century....

    leetcode中国-fuck_offer:fuck_offer

    俄罗斯URAL联邦大学Online Judge Aizu : 日本会津大学Online Judge SPOJ : SPOJ是波兰最为出色的Online Judge之一 , 界面和谐题目类型也非常丰富 , 适合有一定基础的选手练习 , 对高手而言也是个提高能力的良好平台 ...

Global site tag (gtag.js) - Google Analytics