hdu 1892 树状数组
思路:就是一个很普通的二维树状数组,注意的是x1,y1不一定在x2,y2的左下方。
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cstdio>
#define Maxn 1105
#define lowbit(x) (x&(-x))
using namespace std;
int C[Maxn][Maxn],n=,LIST[Maxn][Maxn];
int Sum(int i,int j)
{
int sum=;
int y;
y=j;
while(i)
{
j=y;
while(j)
{
sum+=C[i][j];
j-=lowbit(j);
}
i-=lowbit(i);
}
return sum;
}
void update(int i,int j,int val)
{
int y,z;
y=j;
while(i<=n)
{
j=y;
while(j<=n)
{
C[i][j]+=val;
j+=lowbit(j);
}
i+=lowbit(i);
}
}
int main()
{
int x1,x2,y1,y2,q,t,num,i,Case=,j;
char str[];
for(i=;i<=;i++)
for(j=;j<=;j++)
update(i,j,);
for(i=;i<=;i++)
for(j=;j<=;j++)
LIST[i][j]=C[i][j];
scanf("%d",&t);
Case=;
while(t--)
{
memcpy(C,LIST,sizeof(C));
scanf("%d",&q);
printf("Case %d:\n",++Case);
for(i=;i<=q;i++)
{
scanf("%s",&str);
if(str[]=='S')
{
scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
x1++,y1++,x2++,y2++;
int a1,b1,a2,b2;
a1=min(x1,x2);a2=max(x1,x2);b1=min(y1,y2);b2=max(y1,y2);
printf("%d\n",Sum(a2,b2)-Sum(a1-,b2)-Sum(a2,b1-)+Sum(a1-,b1-));
}
if(str[]=='A')
{
scanf("%d%d%d",&x1,&y1,&num);
x1++,y1++;
update(x1,y1,num);
//printf("%d**\n",Sum(x1,y1));
}
if(str[]=='D')
{
int temp;
scanf("%d%d%d",&x1,&y1,&num);
x1++,y1++;
temp=Sum(x1,y1)-Sum(x1-,y1)-Sum(x1,y1-)+Sum(x1-,y1-);
if(temp>=num)
update(x1,y1,-num);
else
update(x1,y1,-temp);
}
if(str[]=='M')
{
scanf("%d%d%d%d%d",&x1,&y1,&x2,&y2,&num);
x1++,y1++,x2++,y2++;
int temp=Sum(x1,y1)-Sum(x1-,y1)-Sum(x1,y1-)+Sum(x1-,y1-);
if(temp>=num)
{
update(x1,y1,-num);
update(x2,y2,num);
}
else
{
update(x1,y1,-temp);
update(x2,y2,temp);
}
}
}
}
return ;
}
hdu 1892 树状数组的更多相关文章
- hdu 4638 树状数组 区间内连续区间的个数(尽可能长)
Group Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Subm ...
- hdu 4777 树状数组+合数分解
Rabbit Kingdom Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) T ...
- HDU 2852 (树状数组+无序第K小)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2852 题目大意:操作①:往盒子里放一个数.操作②:从盒子里扔掉一个数.操作③:查询盒子里大于a的第K小 ...
- HDU 4911 (树状数组+逆序数)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4911 题目大意:最多可以交换K次,就最小逆序对数 解题思路: 逆序数定理,当逆序对数大于0时,若ak ...
- hdu 5792(树状数组,容斥) World is Exploding
hdu 5792 要找的无非就是一个上升的仅有两个的序列和一个下降的仅有两个的序列,按照容斥的思想,肯定就是所有的上升的乘以所有的下降的,然后再减去重复的情况. 先用树状数组求出lx[i](在第 i ...
- HDU 1934 树状数组 也可以用线段树
http://acm.hdu.edu.cn/showproblem.php?pid=1394 或者是我自己挂的专题http://acm.hust.edu.cn/vjudge/contest/view. ...
- 2018 CCPC网络赛 1010 hdu 6447 ( 树状数组优化dp)
链接:http://acm.hdu.edu.cn/showproblem.php?pid=6447 思路:很容易推得dp转移公式:dp[i][j] = max(dp[i][j-1],dp[i-1][j ...
- 【模板】HDU 1541 树状数组
http://acm.hdu.edu.cn/showproblem.php?pid=1541 题意:给你一堆点,每个点右一个level,为其右下方所有点的数量之和,求各个level包含的点数. 题解: ...
- hdu 5147 树状数组
题意:求满足a<b<c<d,A[a]<A[b],A[c]<A[d]的所有四元组(a,b,c,d)的个数 看到逆序对顺序对之类的问题一开始想到了曾经用归并排序求逆序对,结果 ...
随机推荐
- 提高iOS开发效率的方法和工具
http://www.cocoachina.com/ios/20150717/12626.html 介绍 这篇文章主要是介绍一下我在iOS开发中使用到的一些可以提升开发效率的方法和工具. IDE 首先 ...
- UVA 10054 The Necklace(欧拉回路,打印路径)
题目链接: http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem ...
- UVaLive 7269 Snake Carpet (找规律,模拟)
题意:给定一个数字n,表示有n条蛇,然后蛇的长度是 i ,如果 i 是奇数,那么它只能拐奇数个弯,如果是偶数只能拐偶数个,1, 2除外,然后把这 n 条蛇, 放到一个w*h的矩阵里,要求正好放满,让你 ...
- [转载代码]VB.NET 中查询 Linq to SQL 执行时的SQL语句
在搜索使用LINQ TO SQL 添加数据后获得自增长ID的方法时,发现C#可以使用DebuggerWritter把使用Linq to SQL执行的SQL语句显示到即时窗口,于是在网上搜索到在VB.N ...
- Oracle-11g-R2(11.2.0.3.x)RAC Oracle Grid & Database 零宕机方式升级 PSU(自动模式)
升级环境: 1.源库版本: Grid Infrastructure:11.2.0.3.13 Database:11.2.0.3.13 2.目标库版本: Grid Infrastructure:11.2 ...
- CSMA/CD协议——学习笔记
CSMA/CD协议要点: 1)适配器从网络层获得一个分组,加上以太网的首部和尾部,组成以太网帧,放入适配器的缓存中,准备发送. 2)若适配器检测到信道空闲(即在96比特时间内没有检测到信道上有信号), ...
- cocos2d-x 获取系统时间
转自:http://blog.csdn.net/jinjian2009/article/details/9449585 之前使用过cocos2d-x获取系统时间,毫秒级的 long getCurren ...
- Klist
显示当前缓存的 Kerberos 票证的列表. 有关如何使用此命令的示例 语法 klist [-<LogonId.HighPart> lh] [-li <LogonId.LowPar ...
- ListView美化:去阴影、底色、选中色
原文:http://blog.csdn.net/wxg630815/article/details/6987305 1.去滑动到顶点和底边时的黑色阴影 [html] view plaincopy ...
- 有图有真相,分享一款网页版HTML5飞机射击游戏
本飞机射击游戏是使用HTML5代码写的,尝试通过统一开发环境(UDE)将游戏托管在MM应用引擎,直接生成了网页版游戏,游戏简单易上手,非常适合用来当做小休闲打发时间. 游戏地址:http://flyg ...