二维树状数组poj1195
题目链接:https://vjudge.net/problem/POJ-1195
题意:一开始输入0和一个s,0代表开始,s代表这是一个s*s的图,接下来会输入1或2,1代表进行单点修改,后面会接3个数字x,y,value,表示把坐标(x,y)增加value,如果是2则代表区间查询,后面会跟两个点的坐标x1,y1,x2,y2,查询这两个点中间区间的区间和。我做的第一道二维数组的题目,感觉有点坑。
不知道二维数组,但是知道一维的可以这篇博客:https://blog.csdn.net/z309241990/article/details/9615259
一维也不清楚的大胸弟可以看这篇:https://blog.csdn.net/int64ago/article/details/7429868
这里比较坑的就是区间求和,对于两个点(x1,y1)(x2,y2)中间区间的区间和是这样的
sum(x2,y2)-sum(x1-1,y2)-sum(x2,y1-1)+sum(x1-1,y1-1);会减去重复部分,所以要加回来,这个画图还是可以理解的,一开始可能反应不过来,为了防止死循环,我把每个点的横纵坐标都加一,比较安全。
代码:
#include<iostream>
#include<cstring>
#include<algorithm>
#include<queue>
#include<map>
#include<stack>
#include<cmath>
#include<vector>
#include<set>
#include<cstdio>
#include<string>
#include<deque>
using namespace std;
typedef long long LL;
#define eps 1e-8
#define INF 0x3f3f3f3f
#define maxn (1<<10)+2
LL a[maxn][maxn];
int n,m,k,t;
int op,x1,x2,yy1,y2,value;
int lowbit(int x){
return x&(-x);
}
void add(int x,int y,int value){//二维树状数组单点修改
for(int i=x;i<maxn;i+=lowbit(i)){
for(int j=y;j<maxn;j+=lowbit(j)){
a[i][j]+=value;
}
}
}
LL sum(int x,int y){//二维树状数组区间求和
LL ans=;
for(int i=x;i>;i-=lowbit(i)){
for(int j=y;j>;j-=lowbit(j)){
ans+=a[i][j];
}
}
return ans;
}
int main()
{
while(scanf("%d",&op)!=EOF){
scanf("%d",&n);
memset(a,,sizeof(a));
while(scanf("%d",&op)&&op!=){
if(op==){
scanf("%d%d%d",&x1,&yy1,&value);
x1++;
yy1++;
add(x1,yy1,value);
}else if(op==){
scanf("%d%d%d%d",&x1,&yy1,&x2,&y2);
x1++;
yy1++;
x2++;
y2++;
LL ans=sum(x2,y2)-sum(x1-,y2)-sum(x2,yy1-)+sum(x1-,yy1-);
printf("%lld\n",ans);
}
}
}
return ;
}
二维树状数组poj1195的更多相关文章
- poj1195(二维树状数组)
		
题目链接:https://vjudge.net/problem/POJ-1195 题意:有s*s的矩阵,初始化为全0,有两种操作,单点修改(x,y)的值,区间查询(x,y)的值(l<=x< ...
 - POJ-1195 Mobile phones---裸的二维树状数组(注意下标从1,1开始)
		
题目链接: https://vjudge.net/problem/POJ-1195 题目大意: 直接维护二维树状数组 注意横纵坐标全部需要加1,因为树状数组从(1,1)开始 #include<c ...
 - 二维树状数组(水题) POJ1195
		
前段时间遇到线段树过不了,树状数组却过了的题.(其实线段树过得了的) 回忆了下树状数组. 主要原理,还是二进制位数,每一项的和表示其为它的前((最后一位1及其后)的二进制数)和,可从二进制图来看.(用 ...
 - 【POJ1195】【二维树状数组】Mobile phones
		
Description Suppose that the fourth generation mobile phone base stations in the Tampere area operat ...
 - poj1195二维树状数组模板
		
二维树状数组和一维的也差不多,改一下add和query函数即可:即按行修改,行内单点修改即可 /* 二维树状数组,询问一个二维区间内的数之和 */ #include<iostream> # ...
 - 【poj1195】Mobile phones(二维树状数组)
		
题目链接:http://poj.org/problem?id=1195 [题意] 给出一个全0的矩阵,然后一些操作 0 S:初始化矩阵,维数是S*S,值全为0,这个操作只有最开始出现一次 1 X Y ...
 - POJ1195(二维树状数组)
		
Mobile phones Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 17176 Accepted: 7920 De ...
 - 二维树状数组 BZOJ 1452 [JSOI2009]Count
		
题目链接 裸二维树状数组 #include <bits/stdc++.h> const int N = 305; struct BIT_2D { int c[105][N][N], n, ...
 - HDU1559 最大子矩阵  (二维树状数组)
		
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1559 最大子矩阵 Time Limit: 30000/10000 MS (Java/Others) ...
 
随机推荐
- jquery绑定回车事件
			
//回车事件绑定 $(".left-content").keyup(function(event){ var theEvent = event || window.event; v ...
 - Unreal Engine 4 C++ UCLASS构造函数易出错分析
			
Unreal Engine 4 C UCLASS构造函数易出错分析 GENERATED_BODY GENERATED_UCLASS_BODY 在Unreal Engine 4的任意类中通常会见到两个宏 ...
 - kolla单节点部署openstack
			
virtualbox环境: 双网卡:enp0s3(桥接) 192.168.102.194 enp0s8(桥接) 无ip 块存储 50G 关闭防火墙,selinux. 配置yum源:wget ...
 - 【SpringBoot】SpringBoot2.0响应式编程
			
========================15.高级篇幅之SpringBoot2.0响应式编程 ================================ 1.SprinBoot2.x响应 ...
 - int和integer的区别和使用
			
基本数据类型和引用数据类型的区别和介绍:https://www.cnblogs.com/bekeyuan123/p/7468845.html 1.int是基本数据类型,integer是引用数据类型,是 ...
 - Python的深copy和浅copy
			
浅拷贝(copy):拷贝父对象,不会拷贝对象的内部的子对象. 深拷贝(deepcopy): copy 模块的 deepcopy 方法,完全拷贝了父对象及其子对象. 浅copy: a = [1, 2, ...
 - Nuke Python module的使用
			
最近很多脚本工作都需要脱离nuke的gui环境运行,没有了script editor就必须要尝试Nuke Python module功能了.该模式可以执行大部分在GUI环境中的命令,在自动生成或者批量 ...
 - 【C++】vector内存机制和性能分析
			
转自:https://blog.csdn.net/mfcing/article/details/8746256 一些好的公司校园招聘过程中(包括笔试.面试环节),经常会涉及到STL中vector的使用 ...
 - 多版本opencv管理; find_package()的原理解析
			
近期用cmake编译程序时,报错找不到opencv2.由于我电脑里安装了多个版本的opencv,管理不善,借此机会梳理一下思路. 1. Cmake -- find_package(Opencv REQ ...
 - 【剑指offer】判断出栈序列是否合法
			
输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序.假设压入栈的所有数字均不相等.例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应 ...