首页 > 代码库 > POJ 2155 Matrix(树状数组+容斥原理)
POJ 2155 Matrix(树状数组+容斥原理)
【题目链接】 http://poj.org/problem?id=2155
【题目大意】
要求维护两个操作,矩阵翻转和单点查询
【题解】
树状数组可以处理前缀和问题,前缀之间进行容斥即可得到答案。
【代码】
#include <cstring>#include <cstdio>const int N=1010;using namespace std;int c[N][N],n,m,T;char op[2];void add(int x,int y){ int i,j,k; for(i=x;i<N;i+=i&-i) for(j=y;j<N;j+=j&-j) c[i][j]^=1;}int sum(int x,int y){ int i,j,ret=0; for(i=x;i;i-=i&-i) for(j=y;j;j-=j&-j) ret^=c[i][j]; return ret;}int main(){ scanf("%d",&T); for(int cas=0;cas<T;cas++){ if(cas)puts(""); memset(c,0,sizeof(c)); scanf("%d%d",&n,&m); while(m--){ int x,y,x1,y1; scanf("%s%d%d",op,&x,&y); if(op[0]==‘Q‘)printf("%d\n",sum(x,y)); else{ scanf("%d%d",&x1,&y1); add(x,y); add(x1+1,y); add(x,y1+1); add(x1+1,y1+1); } } }return 0;}
POJ 2155 Matrix(树状数组+容斥原理)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。