【树状数组】[CodeForces - 341D]Iahub and Xors

CodeForces - 341D
分析:异或有一个性质:a^b=c,a^c=b,b^c=a;
然后就可以,直接用二维树状数组,具体还可以参见上帝造题的七分钟

代码:

#include<cstdio>
#define MAXN 1000
int n,m,c[MAXN+10][MAXN+10],ci[MAXN+10][MAXN+10],cj[MAXN+10][MAXN+10],cij[MAXN+10][MAXN+10];
void Read(int &x){
    char c;
    while(c=getchar(),c!=EOF)
        if(c>='0'&&c<='9'){
            x=c-'0';
            while(c=getchar(),c>='0'&&c<='9')
                x=x*10+c-'0';
            ungetc(c,stdin);
            return;
        }
}
inline int lowbit(int x){
    return x&-x;
}
void update(int c[][MAXN+10],int x,int y,int d){
    int j;
    for(;x<=n;x+=lowbit(x))
        for(j=y;j<=n;j+=lowbit(j))
            c[x][j]^=d;
}
int getsum(int c[][MAXN+10],int x,int y){
    int j,ret=0;
    for(;x;x-=lowbit(x))
        for(j=y;j;j-=lowbit(j))
            ret^=c[x][j];
    return ret;
}

int main()
{
    Read(n),Read(m);
    int p,x1,y1,x0,y0,v,a1,a2,a3,a4;
    while(m--){
        Read(p);
        if(p==2){
            Read(x0),Read(y0),Read(x1),Read(y1),Read(v);
            update(c,x0,y0,v);
            update(ci,x0,y0,x0&1?v:0);
            update(cj,x0,y0,y0&1?v:0);
            update(cij,x0,y0,(x0*y0)&1?v:0);
            update(c,x0,y1+1,v);
            update(ci,x0,y1+1,x0&1?v:0);
            update(cj,x0,y1+1,(y1+1)&1?v:0);
            update(cij,x0,y1+1,(x0*(y1+1))&1?v:0);
            update(c,x1+1,y0,v);
            update(ci,x1+1,y0,(x1+1)&1?v:0);
            update(cj,x1+1,y0,y0&1?v:0);
            update(cij,x1+1,y0,((x1+1)*y0)&1?v:0);
            update(c,x1+1,y1+1,v);
            update(ci,x1+1,y1+1,(x1+1)&1?v:0);
            update(cj,x1+1,y1+1,(y1+1)&1?v:0);
            update(cij,x1+1,y1+1,((x1+1)*(y1+1))&1?v:0);
        }
        else{
            Read(x0),Read(y0),Read(x1),Read(y1);
            a1=(((x1+1)*(y1+1))&1?getsum(c,x1,y1):0)^((y1+1)&1?getsum(ci,x1,y1):0)^((x1+1)&1?getsum(cj,x1,y1):0)^getsum(cij,x1,y1);
            a2=((x0*(y1+1))&1?getsum(c,x0-1,y1):0)^((y1+1)&1?getsum(ci,x0-1,y1):0)^(x0&1?getsum(cj,x0-1,y1):0)^getsum(cij,x0-1,y1);
            a3=(((x1+1)*y0)&1?getsum(c,x1,y0-1):0)^(y0&1?getsum(ci,x1,y0-1):0)^((x1+1)&1?getsum(cj,x1,y0-1):0)^getsum(cij,x1,y0-1);
            a4=((x0*y0)&1?getsum(c,x0-1,y0-1):0)^(y0&1?getsum(ci,x0-1,y0-1):0)^(x0&1?getsum(cj,x0-1,y0-1):0)^getsum(cij,x0-1,y0-1);
            printf("%d\n",a1^a2^a3^a4);
        }
    }
}

转载于:https://www.cnblogs.com/outerform/p/5921926.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值