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)上的数全部 ...
随机推荐
- python django 基本环境配置
创建虚拟环境: python -m venv django启动虚拟环境: .\venv\Scripts\activate下载django: pip install django查看django命令: ...
- day4(dict和set)
dict 内置字典,使用key-value存储,具有极快的查找速度. >>>d = {'michael': 95, 'bob': 75, 'tracy': 85} >>& ...
- PHP的一些安全设置
小伙伴们新年好啊,又有半个月没有更新博客了.更新也比较随性,想起什么就写点什么,方便和大家工作同学习总结. 最近和同事说起了PHP安全相关的问题,记录下一些心得体会. 由于脚本语言和早期版本设计的诸多 ...
- 【转】经典的SQL语句面试题
Student(S#,Sname,Sage,Ssex) 学生表Course(C#,Cname,T#) 课程表SC(S#,C#,score) 成绩表Teacher(T#,Tname) 教师表 问题: 1 ...
- floj 2264
2.公路建设(highway.c/cpp/pas) 在滨海市一共有n 个城市,编号依次为1到n,它们之间计划修建m条双向道路,其中修建第i条道路的费用为ci. 海霸王作为滨海市公路建设项目的总工程师, ...
- CocoaPods中的头文件import导入时不能自动补齐的解决方法
1.选择target(就是左边你的工程target)-->BuildSettings-->search Paths下的User Header Search Paths 2.添加“$(POD ...
- unbuntu18.04安装启用splash
官网:https://splash.readthedocs.io/en/stable/ 1.安装Docker https://www.cnblogs.com/wt7018/p/11880666.htm ...
- Java入门 - 语言基础 - 07.修饰符
原文地址:http://www.work100.net/training/java-modifier-type.html 更多教程:光束云 - 免费课程 修饰符 序号 文内章节 视频 1 概述 2 访 ...
- 「 深入浅出 」java集合Collection和Map
本系列文章主要对java集合的框架进行一个深入浅出的介绍,使大家对java集合有个深入的理解. 本篇文章主要具体介绍了Collection接口,Map接口以及Collection接口的三个子接口Set ...
- python实现数据结构-队列
注:本文档主要是学习<Python核心编程(第二版)>时的练习题. 队列是一种"先进先出"的数据结构(FIFO),是一种操作受限的线性结构,先进队列的成员先出队列.示意 ...