poj1195 Mobile phones
2016-07-25 09:33
375 查看
裸的二维树状数组
#include<stdio.h>
#include<string.h>
#define maxn 1100
int tree[maxn][maxn];
int lowbit(int x)
{
return x&(-x);
}
void update(int x,int y,int num,int R,int C)
{
int i,j;
for(i=x;i<=R;i+=lowbit(i))
for(j=y;j<=C;j+=lowbit(j))
tree[i][j]+=num;
}
int sum(int x,int y)
{
int i,j,s=0;
for(i=x;i>0;i-=lowbit(i))
for(j=y;j>0;j-=lowbit(j))
s+=tree[i][j];
return s;
}
int getsum(int x1,int y1,int x2,int y2)
{
return sum(x2,y2)-sum(x1-1,y2)-sum(x2,y1-1)+sum(x1-1,y1-1);
}
int main()
{
int op,n;
memset(tree,0,sizeof(tree));
while(scanf("%d",&op),op!=3)
{
if(op==0)
scanf("%d",&n);
else if(op==1)
{
int x,y,a;
scanf("%d%d%d",&x,&y,&a);
update(x+1,y+1,a,n,n);
}
else if(op==2)
{
int l,r,b,t;
scanf("%d%d%d%d",&l,&b,&r,&t);
printf("%d\n",getsum(l+1,b+1,r+1,t+1));
}
}
}
#include<stdio.h>
#include<string.h>
#define maxn 1100
int tree[maxn][maxn];
int lowbit(int x)
{
return x&(-x);
}
void update(int x,int y,int num,int R,int C)
{
int i,j;
for(i=x;i<=R;i+=lowbit(i))
for(j=y;j<=C;j+=lowbit(j))
tree[i][j]+=num;
}
int sum(int x,int y)
{
int i,j,s=0;
for(i=x;i>0;i-=lowbit(i))
for(j=y;j>0;j-=lowbit(j))
s+=tree[i][j];
return s;
}
int getsum(int x1,int y1,int x2,int y2)
{
return sum(x2,y2)-sum(x1-1,y2)-sum(x2,y1-1)+sum(x1-1,y1-1);
}
int main()
{
int op,n;
memset(tree,0,sizeof(tree));
while(scanf("%d",&op),op!=3)
{
if(op==0)
scanf("%d",&n);
else if(op==1)
{
int x,y,a;
scanf("%d%d%d",&x,&y,&a);
update(x+1,y+1,a,n,n);
}
else if(op==2)
{
int l,r,b,t;
scanf("%d%d%d%d",&l,&b,&r,&t);
printf("%d\n",getsum(l+1,b+1,r+1,t+1));
}
}
}
相关文章推荐
- PHP error_reporting() 错误控制函数功能详解
- 实现微信订阅号强制关注
- eclipse 查看版本号及优化运行速度
- note
- iOS开发的一些奇巧淫技
- mysql常用函数汇总(分享)
- Demo_java_自定义复制(I/O流, 集合 File类)
- 2016夏季练习——KMP
- Android apk重签名
- 自己动手写一个java版简单云相册
- STM32-USMART调试组件
- jquery美化select,自定义下拉框样式
- 07.25新的一周,踏实,努力
- GitHub上那些值得一试的Java开源库
- 【HDU5748 BestCoder Round 84B】【LIS模板 最长单调上升子序列】Bellovin 以尾端点最长LIS压缩数组
- hdu2502-月之数 注意int double范围
- Android 中RecyclerView使用详解(一)
- hibernate.current_session_context_class 的各个取值的区别以及与Spring整合的问题
- Python打包为exe使用py2exe时中文乱码问题
- java高仿百度贴吧九宫格验证码代码下载