标签:
Description
Input
Output
Sample Input
1 2 10 C 2 1 2 2 Q 2 2 C 2 1 2 1 Q 1 1 C 1 1 2 1 C 1 2 1 2 C 1 1 2 2 Q 1 1 C 1 1 2 1 Q 2 1
Sample Output
1 0 0 1
Source
#include <iostream> #include <stdio.h> #include <string.h> #include <string> #include <stack> #include <queue> #include <map> #include <set> #include <vector> #include <math.h> #include <bitset> #include <list> #include <algorithm> #include <climits> using namespace std; #define lson 2*i #define rson 2*i+1 #define LS l,mid,lson #define RS mid+1,r,rson #define UP(i,x,y) for(i=x;i<=y;i++) #define DOWN(i,x,y) for(i=x;i>=y;i--) #define MEM(a,x) memset(a,x,sizeof(a)) #define W(a) while(a) #define gcd(a,b) __gcd(a,b) #define LL long long #define N 1005 #define INF 0x3f3f3f3f #define EXP 1e-8 #define lowbit(x) (x&-x) const int mod = 1e9+7; int c[N][N],n,m,cnt,s,t; int a[N][N]; int sum(int x,int y) { int ret = 0; int i,j; for(i = x;i>=1;i-=lowbit(i)) { for(j = y;j>=1;j-=lowbit(j)) { ret+=c[i][j]; } } return ret; } void add(int x,int y) { int i,j; for(i = x;i<=n;i+=lowbit(i)) { for(j = y;j<=n;j+=lowbit(j)) { c[i][j]++; } } } int main() { int i,j,x,y,ans,t; int x1,x2,y1,y2; char op[10]; scanf("%d",&t); while(t--) { scanf("%d%d",&n,&m); MEM(c,0); MEM(a,0); while(m--) { scanf("%s",op); if(op[0]=='C') { scanf("%d%d%d%d",&x1,&y1,&x2,&y2); x1++,y1++,x2++,y2++; add(x2,y2); add(x1-1,y1-1); add(x2,y1-1); add(x1-1,y2); } else { scanf("%d%d",&x1,&y1); x2 = x1,y2 = y1; x1++,y1++,x2++,y2++; printf("%d\n",sum(x1,y1)); } } printf("\n"); } return 0; }
标签:
原文地址:http://www.cnblogs.com/yxwkf/p/5090566.html