http://acm.hdu.edu.cn/showproblem.php?pid=1892
二维树状数组求子段和
#include <iostream>
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
using namespace std;
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
const int MAX=1002;
int a[MAX][MAX],c[MAX][MAX];
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
int lowbit(int i)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
return i&(-i);
}
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
int max(int i,int j)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
return i>j? i:j;
}
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
int min(int i,int j)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
return i<j? i:j;
}
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
void modify(int x,int y,int num)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
int i,j;
for(i=x;i<MAX;i+=lowbit(i))
for(j=y;j<MAX;j+=lowbit(j))
c[i][j]+=num;
}
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
int sum(int x,int y)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
int s=0,i,j;
for(i=x;i>0;i-=lowbit(i))
for(j=y;j>0;j-=lowbit(j))
s+=c[i][j];
return s;
}
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
void init()
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
int i,j;
for(i=1;i<MAX;i++)
for(j=1;j<MAX;j++)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
a[i][j]=1;
c[i][j]=lowbit(i)*lowbit(j);
}
}
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
int main()
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
data:image/s3,"s3://crabby-images/3ee79/3ee79ec5a9b7f3dd33bbbdc97980715db1aa9f00" alt=""
{
int i,n,t,j,s,x1,x2,y1,y2,maxx,maxy,minx,miny,temp,x,y,num;
char ch;
scanf("%d",&t);
for(i=1;i<=t;i++)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
init();
scanf("%d",&n);
printf("Case %d:\n",i);
while(n--)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
getchar();
scanf("%c ",&ch);
if(ch=='S')
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
scanf("%d %d %d %d",&x1,&y1,&x2,&y2);
x1++;y1++;x2++;y2++;
maxx=max(x1,x2);
maxy=max(y1,y2);
minx=min(x1,x2);
miny=min(y1,y2);
temp=sum(maxx,miny-1)+sum(minx-1,maxy)-sum(minx-1,miny-1);
s=sum(maxx,maxy)-temp;
printf("%d\n",s);
continue;
}
if(ch=='A')
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
scanf("%d %d %d",&x,&y,&num);
x++;y++;
a[x][y]+=num;
modify(x,y,num);
continue;
}
if(ch=='D')
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
scanf("%d %d %d",&x,&y,&num);
x++;y++;
if(num>a[x][y])
num=a[x][y];
a[x][y]-=num;
modify(x,y,-num);
continue;
}
if(ch=='M')
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
scanf("%d %d %d %d %d",&x1,&y1,&x2,&y2,&num);
x1++;y1++;x2++;y2++;
if(num>a[x1][y1])
num=a[x1][y1];
a[x1][y1]-=num;
a[x2][y2]+=num;
modify(x1,y1,-num);
modify(x2,y2,num);
continue;
}
}
}
return 0;
}
posted on 2011-09-03 10:49
大大木马 阅读(197)
评论(0) 编辑 收藏 引用