0
点赞
收藏
分享

微信扫一扫

Matrix POJ - 2155


二维线段树模版题

这篇博客的染色和翻转问题说的很明白​​点击打开链接​​ 之前一直没有考虑这么细·

 

#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;

int tree[4010][4010];
int n,ans;

void updatey(int yl,int yr,int curx,int l,int r,int cury)
{
int m;
if(yl<=l&&r<=yr)
{
tree[curx][cury]++;
return;
}
m=(l+r)/2;
if(yl<=m) updatey(yl,yr,curx,l,m,cury*2);
if(yr>=m+1) updatey(yl,yr,curx,m+1,r,cury*2+1);
return;
}

void updatex(int xl,int xr,int yl,int yr,int l,int r,int curx)
{
int m;
if(xl<=l&&r<=xr)
{
updatey(yl,yr,curx,1,n,1);
return;
}
m=(l+r)/2;
if(xl<=m) updatex(xl,xr,yl,yr,l,m,curx*2);
if(xr>=m+1) updatex(xl,xr,yl,yr,m+1,r,curx*2+1);
return;
}

void queryy(int tary,int curx,int l,int r,int cury)
{
int m;
ans+=tree[curx][cury];
if(l==r) return;
m=(l+r)/2;
if(tary<=m) queryy(tary,curx,l,m,cury*2);
else queryy(tary,curx,m+1,r,cury*2+1);
return;
}

void queryx(int tarx,int tary,int l,int r,int curx)
{
int m;
queryy(tary,curx,1,n,1);
if(l==r) return;
m=(l+r)/2;
if(tarx<=m) queryx(tarx,tary,l,m,curx*2);
else queryx(tarx,tary,m+1,r,curx*2+1);
return;
}

int main()
{
int t,q,x1,y1,x2,y2;
char ch[2];
scanf("%d",&t);
while(t--)
{
scanf("%d%d",&n,&q);
memset(tree,0,sizeof(tree));
while(q--)
{
scanf("%s",ch);
if(ch[0]=='C')
{
scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
updatex(x1,x2,y1,y2,1,n,1);
}
else
{
scanf("%d%d",&x1,&y1);
ans=0;
queryx(x1,y1,1,n,1);
printf("%d\n",ans%2);
}
}
printf("\n");
}
return 0;
}

 

 

 


举报

相关推荐

0 条评论