首页 > 其他 > 详细

poj-3225-Help with Intervals

时间:2014-06-19 12:02:40      阅读:462      评论:0      收藏:0      [点我收藏+]

超级恶心的一道题目。。。

查错查了一个小时。。。。

1,要用C++,用G++会wa。

2,注意检查边界。

3,注意标记的下放方式。

#include<stdio.h>
#include<iostream>
#include<stdlib.h>
#include<string.h>
#include<algorithm>
#include<vector>
#include<math.h>
#include<map>
#pragma comment(linker, "/STACK:1024000000,1024000000")
using namespace std;
#define maxn 200000
#define mem(a,b) (memset(a),b,sizeof(a))
#define lmin 0
#define rmax n
#define lson l,(l+r)/2,rt<<1
#define rson (l+r)/2+1,r,rt<<1|1
#define root lmin,rmax,1
#define now l,r,rt
#define int_now int l,int r,int rt
#define INF 99999999
#define LL __int64
#define mod 10007
#define eps 1e-6
#define zero(x) (fabs(x)<eps?0:x)
int rev[maxn*4];
int val[maxn*4];
int ans[maxn];
void push_down(int_now)
{
    if(val[rt]!=-1)
    {
        val[rt<<1]=val[rt<<1|1]=val[rt];
        rev[rt<<1]=rev[rt<<1|1]=rev[rt];
        rev[rt]=0;
        val[rt]=-1;
    }
    if(rev[rt])
    {
        if(val[rt<<1]!=-1)val[rt<<1]^=1;
        else rev[rt<<1]^=1;
        if(val[rt<<1|1]!=-1)val[rt<<1|1]^=1;
        else rev[rt<<1|1]^=1;
        rev[rt]=0;
    }
}
void updata(int ll,int rr,int x,int_now)
{
    if(ll>r||rr<l)return;
    if(ll<=l&&rr>=r)
    {
        val[rt]=x;
        rev[rt]=0;
        return;
    }
    push_down(now);
    updata(ll,rr,x,lson);
    updata(ll,rr,x,rson);
}
void fan(int ll,int rr,int_now)
{
    if(ll>r||rr<l)return;
    if(ll<=l&&rr>=r)
    {
        if(val[rt]!=-1)val[rt]^=1;
        else  rev[rt]^=1;
        return;
    }
    push_down(now);
    fan(ll,rr,lson);
    fan(ll,rr,rson);
}
void query(int_now)
{
    if(l==r)
    {
        if(val[rt]==1)ans[l]=1;
        return;
    }
    push_down(now);
    query(lson);
    query(rson);
}
int main()
{
    int n=65537*2;
    char ch[100];
    char le,ri;
    int l,r;
    while(scanf("%s%*c%c%d,%d%c%*c",ch,&le,&l,&r,&ri)!=EOF)
    {
        if(ch[0]=='e')break;
        l=l*2;
        r=r*2;
        if(le=='(')l=l+1;
        if(ri==')')r=r-1;
        if(ch[0]=='U')
        {
            updata(l,r,1,root);
        }
        if(ch[0]=='I')
        {
            if(l-1>=0)updata(0,l-1,0,root);
            updata(r+1,n,0,root);
        }
        if(ch[0]=='D')
        {
            updata(l,r,0,root);
        }
        if(ch[0]=='C')
        {
            if(l-1>=0)updata(0,l-1,0,root);
            updata(r+1,n,0,root);
            fan(l,r,root);
        }
        if(ch[0]=='S')
        {
            fan(l,r,root);
        }
    }
    query(root);
    int flag=0;
    l=r=-1;
    for(int i=0;i<=n;i++)
    {
        if(ans[i])
        {
            if(l==-1)
            {
                l=i;
                if(flag)printf(" ");
                if(l%2)printf("(%d",l/2);
                else printf("%[%d",l/2);
                flag++;
            }
        }
        else
        {
            if(l!=-1)
            {
                r=i-1;
                if(r%2)printf(",%d)",r/2+1);
                else printf(",%d]",r/2);
                flag++;
                l=r=-1;
            }
        }
    }
    if(flag==0)
    {
        printf("empty set");
    }
    puts("");
    return 0;
}






















poj-3225-Help with Intervals,布布扣,bubuko.com

poj-3225-Help with Intervals

原文:http://blog.csdn.net/rowanhaoa/article/details/30075763

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!