HDU_4456_二维树状数组
http://acm.hdu.edu.cn/showproblem.php?pid=4456
第一道二维树状数组就这么麻烦,题目要计算的是一个菱形范围内的和,于是可以把原来的坐标系旋转45度,就是求一个正方形范围内的和,这里还涉及到坐标系平移和放大,由于题目数据较大,用了离散化来保存需要处理的点,放在h数组内,对应的二维树状数组存在tree数组内。
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
using namespace std; inline int lowbit(int x)
{
return x & (-x);
}
int p[],posx[],posy[],v[],h[],tree[],n,m,N,cnt; void update(int x,int y,int z)
{
for(int i = x;i <= N;i += lowbit(i))
{
for(int j = y;j <= N;j += lowbit(j))
{
int pos = lower_bound(h,h+cnt,i*N+j)-h;
tree[pos] += z;
}
}
} int getsum(int x,int y)
{
int ans = ;
for(int i = x;i > ;i -= lowbit(i))
{
for(int j = y;j > ;j -= lowbit(j))
{
int pos = lower_bound(h,h+cnt,i*N+j)-h;
if(h[pos] == i*N+j) ans += tree[pos];
}
}
return ans;
} int main()
{
while(scanf("%d",&n) && n)
{
memset(tree,,sizeof(tree));
int x,y;
N = *n;
cnt = ;
scanf("%d",&m);
for(int i = ;i <= m;i++)
{
scanf("%d%d%d%d",&p[i],&x,&y,&v[i]);
int xx = x-y+n,yy = x+y;
posx[i] = xx;
posy[i] = yy;
if(p[i] == )
{
for(int j = xx;j <= N;j += lowbit(j))
{
for(int k = yy;k <= N;k += lowbit(k))
{
h[cnt++] = j*N+k;
}
}
}
}
sort(h,h+cnt);
for(int i = ;i <= m;i++)
{
if(p[i] == ) update(posx[i],posy[i],v[i]);
else
{
int x1 = max(,posx[i]-v[i]),y1 = max(,posy[i]-v[i]);
int x2 = min(N,posx[i]+v[i]),y2 = min(N,posy[i]+v[i]);
printf("%d\n",getsum(x2,y2)-getsum(x2,y1-)-getsum(x1-,y2)+getsum(x1-,y1-));
}
}
}
return ;
}
HDU_4456_二维树状数组的更多相关文章
- 二维树状数组 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) ...
- POJMatrix(二维树状数组)
Matrix Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 22058 Accepted: 8219 Descripti ...
- poj 1195:Mobile phones(二维树状数组,矩阵求和)
Mobile phones Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 14489 Accepted: 6735 De ...
- Codeforces Round #198 (Div. 1) D. Iahub and Xors 二维树状数组*
D. Iahub and Xors Iahub does not like background stories, so he'll tell you exactly what this prob ...
- POJ 2155 Matrix(二维树状数组+区间更新单点求和)
题意:给你一个n*n的全0矩阵,每次有两个操作: C x1 y1 x2 y2:将(x1,y1)到(x2,y2)的矩阵全部值求反 Q x y:求出(x,y)位置的值 树状数组标准是求单点更新区间求和,但 ...
- [poj2155]Matrix(二维树状数组)
Matrix Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 25004 Accepted: 9261 Descripti ...
- POJ 2155 Matrix (二维树状数组)
Matrix Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 17224 Accepted: 6460 Descripti ...
- [POJ2155]Matrix(二维树状数组)
题目:http://poj.org/problem?id=2155 中文题意: 给你一个初始全部为0的n*n矩阵,有如下操作 1.C x1 y1 x2 y2 把矩形(x1,y1,x2,y2)上的数全部 ...
随机推荐
- HR系列GPS北斗时间同步服务器在电力系统典型应用
HR系列GPS北斗时间同步服务器在电力系统典型应用 时间同步系统主要由主时钟.若干从时钟.时间信号传输介质组成.根据时间同步现场的不同要求,时间同步系统的结构配置有多种形式,主要分为三种:基本式.主从 ...
- JVM之GC(一)
Java较C而言,最大的区别在于内存管理.JVM设有无用内存空间自动回收复用机制,也就是我们所说的GC. 之前说过,栈是为线程.为函数的执行分配内存的地方,用完即“销毁”,这里留待以后做深入探讨:堆是 ...
- 2019牛客暑期多校第五场题解ABGH
A.digits 2 传送门 题意:给你一个n,要求输出一个每一位数字之和能整除n且其本身也能整除n的数.n不超过100,要求的数不超过10000位数. 题解:直接将n输出n次. 代码: #inclu ...
- Flask 作者 Armin Ronacher:我不觉得有异步压力
英文 | I'm not feeling the async pressure[1] 原作 | Armin Ronacher,2020.01.01 译者 | 豌豆花下猫@Python猫 声明 :本翻译 ...
- js 极简获取表单 元素 !
let s =[]; $.each($('#formSearch input'),(m,n)=>{s.push(n)}); //示例获取表单所有 input 下滑线分割的 name 集合.set ...
- python继承简介
继承 是面向对象的三大特性之一 作用: 通过继承可以使一个类获取其它类中的属性和方法 使用方法: 在定义类时,可以在类名后的括号中指定当前类的父类(超类.基类.super) 这样子类(衍生类)就可以直 ...
- Office系列(2)---提取Office文件(Word、PPT)中的所有图片
回顾一下上文结尾的问题:如何给文档设置一个合适的封面图?其中一个解决方案就是,获取Office文件内部的图片作为封面.这里就详细介绍下获取图片的几种方式,以及他们各自的优缺点. PS:因为之前用VST ...
- CAS是什么
CAS是什么? 比较并交换 例子1: public class ABADemo1 { public static void main(String[] args) { AtomicInteger at ...
- Redux 一步到位
简介 Redux 是 JavaScript 状态容器,提供可预测化的状态管理 Redux 除了和 React 一起用外,还支持其它库( jquery ... ) 它体小精悍(只有2kB,包括依赖) 由 ...
- Firebase REST API
use firebase and firesharp to do a Library management system . look github.com/ziyasal/FireSharp