poj 2155 2 Dツリー配列
4058 ワード
题意:あなたに1つのn*n行列をあげて、それからq个の操作、C代表は(x 1、y 1)を左上隅にして(x 2、y 2)を右下角にする行列に対して反対を取って、Q代表は现在(x、y)のこの点の状况を寻ねることを代表して、0ですかそれとも1ですか?
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
using namespace std;
int n;
int c[1001][1001];
int lowbit(int x)
{
return (x)&(-x);
}
void add(int x,int y)
{
while(x<=n)
{
int ty=y;
while(ty<=n)
{
c[x][ty]^=1;
ty+=lowbit(ty);
}
x+=lowbit(x);
}
}
int sum(int x,int y)
{
int s=0;
if(x>n)x=n;
if(y>n)y=n;
while(x>0)
{
int ty=y;
while(ty>0)
{
s^=c[x][ty];
ty-=lowbit(ty);
}
x-=lowbit(x);
}
return s;
}
int main()
{
int t,x1,y1,k,x2,y2;
char s[3];
scanf("%d",&t);
while(t--)
{
scanf("%d%d",&n,&k);
memset(c,0,sizeof(c));
while(k--)
{
scanf("%s",s);
if(s[0]=='C')
{
scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
add(x1,y1);// x2, y2
add(x2+1,y2+1);// ,
add(x1,y2+1);//
add(x2+1,y1);//
}
else
{
scanf("%d%d",&x1,&y1);
printf("%d
",sum(x1,y1));
}
}
if(t)
printf("
");
}
return 0;
}