acdream1197 Points In Cuboid(hash树状数组)
题目链接:http://acdream.info/problem?pid=1197
题意:给出三维空间n个点,m个查询,每次查询某个立方体内的点的个数。
思路:按照一维排序,根据查询插入,其他两位用二位树状数组维护。由于这个坐标太大,二位数组开不出来。这时候就是hash,对于一个位置(x,y),哈希成一个数,作为下标。查询的时候不存在的数字为0.
const int mod=4000007;
const int INF=1000000005;
const int N=100005;
const int M=20011;
struct node
{
int x,y,z;
};
node a[N],b[N][2];
int n,m;
int ans[N];
pii Q[N];
int cmp(node a,node b)
{
return a.z<b.z;
}
int A[mod];
int arr[mod];
inline int ha(int x)
{
int k=x%mod;
int i;
for(i=k;;i++)
{
if(i==mod) i=0;
if(A[i])
{
if(A[i]==x) return i;
}
else
{
A[i]=x;
return i;
}
}
}
inline int find(int x)
{
int k=x%mod;
int i;
for(i=k;;i++)
{
if(i==mod) i=0;
if(A[i])
{
if(A[i]==x) return i;
}
else
{
return i;
}
}
return 0;
}
int que(int x,int y)
{
if(!x||!y) return 0;
int ans=0;
while(x)
{
int i;
for(i=y;i;i-=i&-i)
{
ans+=arr[find(x*M+i)];
}
x-=x&-x;
}
return ans;
}
void add(int x,int y)
{
while(x<M)
{
int i=y;
while(i<M) arr[ha(x*M+i)]++,i+=i&-i;
x+=x&-x;
}
}
int cal(int t)
{
int ans=0;
ans+=que(b[t][1].x,b[t][1].y);
ans-=que(b[t][1].x,b[t][0].y-1);
ans-=que(b[t][0].x-1,b[t][1].y);
ans+=que(b[t][0].x-1,b[t][0].y-1);
return ans;
}
void cal()
{
clr(A,0);
clr(arr,0);
int i;
for(i=1;i<=n;i++)
{
scanf("%d%d%d",&a[i].x,&a[i].y,&a[i].z);
a[i].x+=10005;
a[i].y+=10005;
}
scanf("%d",&m);
int j;
for(i=1;i<=m;i++)
{
for(j=0;j<2;j++)
{
scanf("%d%d%d",&b[i][j].x,&b[i][j].y,&b[i][j].z);
b[i][j].x+=10005;
b[i][j].y+=10005;
}
if(b[i][0].x>b[i][1].x) swap(b[i][0].x,b[i][1].x);
if(b[i][0].y>b[i][1].y) swap(b[i][0].y,b[i][1].y);
if(b[i][0].z>b[i][1].z) swap(b[i][0].z,b[i][1].z);
Q[i*2-1]=MP(b[i][0].z-1,-i);
Q[i*2]=MP(b[i][1].z,i);
}
sort(a+1,a+n+1,cmp);
sort(Q+1,Q+2*m+1);
j=1;
for(i=1;i<=m;i++) ans[i]=0;
for(i=1;i<=n;i++)
{
while(j<=2*m&&Q[j].first<a[i].z)
{
int x=Q[j].second;
if(x>0) ans[x]+=cal(x);
else ans[-x]-=cal(-x);
j++;
}
add(a[i].x,a[i].y);
}
while(j<=2*m)
{
int x=Q[j].second;
if(x>0) ans[x]+=cal(x);
else ans[-x]-=cal(-x);
j++;
}
for(i=1;i<=m;i++) printf("%d\n",ans[i]);
}
int main()
{
int num=0;
while(scanf("%d",&n)!=-1)
{
printf("Case #%d:\n",++num);
cal();
}
}
acdream1197 Points In Cuboid(hash树状数组)的更多相关文章
- [bzoj2124]等差子序列(hash+树状数组)
我又来更博啦 2124: 等差子序列 Time Limit: 3 Sec Memory Limit: 259 MBSubmit: 941 Solved: 348[Submit][Statu ...
- URAL-1989 Subpalindromes 多项式Hash+树状数组
题目链接:http://acm.timus.ru/problem.aspx?space=1&num=1989 题意:给出一个字符串,m个操作:1,修改其中一个字符串,2,询问 [a, b] 是 ...
- P7114 [NOIP2020] 字符串匹配 (字符串hash+树状数组)
好多题解用的扩展KMP(没学过,所以不用这种方法). 我们按照题目要求记F(s)表示s串的权值,可以预处理出前缀权值(用于A)和后缀权值(用于C),枚举AB的长度i=2~n-1,不需要分开枚举,我们只 ...
- CF452F Permutations/Luogu2757 等差子序列 树状数组、Hash
传送门--Luogu 传送门--Codeforces 如果存在长度\(>3\)的等差子序列,那么一定存在长度\(=3\)的等差子序列,所以我们只需要找长度为\(3\)的等差子序列.可以枚举等差子 ...
- bzoj 2124 等差子序列 树状数组维护hash+回文串
等差子序列 Time Limit: 3 Sec Memory Limit: 259 MBSubmit: 1919 Solved: 713[Submit][Status][Discuss] Desc ...
- 【BZOJ2124】等差子序列 树状数组维护hash值
[BZOJ2124]等差子序列 Description 给一个1到N的排列{Ai},询问是否存在1<=p1<p2<p3<p4<p5<…<pLen<=N ...
- ACdreamoj 1011(树状数组维护字符串hash前缀和)
题目链接:http://acdream.info/problem? pid=1019 题意:两种操作,第一种将字符串某个位置的字符换为还有一个字符.另外一种查询某个连续子序列是否是回文串: 解法:有两 ...
- bzoj 1669: [Usaco2006 Oct]Hungry Cows饥饿的奶牛【dp+树状数组+hash】
最长上升子序列.虽然数据可以直接n方但是另写了个nlogn的 转移:f[i]=max(f[j]+1)(a[j]<a[i]) O(n^2) #include<iostream> #in ...
- ural 1989(树状数组+多项式hash)
题意:给出一个字符串.有两种操作,一个是p a b,问字符串从位置a到位置b的子串是否是一个回文子串.还有一个操作 c a b,把字符串位置a的字符替换为b. 题解:由于字符串长度为1e5且问的次数也 ...
随机推荐
- Power Gating的设计(概述)
Leakage power随着CMOS电路工艺进程,功耗越来越大. Power Domain的开关一般通过硬件中的timer和系统层次的功耗管理软件来进行控制,需要在一下几方面做trade-off: ...
- 【ruby】ruby基础知识
Install Ruby(安装) For windows you can download Ruby from http://rubyforge.org/frs/?group_id=167 for L ...
- 【secureCRT】设置自动连接会话+设置自动连接上次使用的会话:
- java简单的数据库查询(SQLServer数据库)
1.数据库链接类 import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; pu ...
- 使用MeanJS Yeoman Generator
1.首先全局安装该生成器 sudo npm install -g generator-meanjs 2.为项目创建一个路径 mkdir xmen && cd xmen 3.创建app ...
- Eclipse如何设置字体
Eclipse 是一个开放源代码的.基于Java的可扩展开发平台,是学习java和开发java最常用的IDE之一.有时候会遇到这种情况,刚刚下载了新的Eclipse,字体显示英文没问题,但是显示中文就 ...
- Oracle触发器使用介绍
触发器,函数,包都是可以再生利用的东西,所以在创建的时候都要用到create or replace这个万能语句,接着就是主角trigger的出现了,主角出现还需要一点点波动,通常大人物都不是随随便便就 ...
- 对已有的2个一维数组,譬如说A[],B[],经过最少循环找出2个数组重复的元素。
import java.util.Arrays; /** * Created by ccc on 16-4-27. */ public class Test { public static void ...
- Linux上部署Tomcat(包括JAVA环境的配置)
一. 用FTP工具,把apache-tomcat-7.0.64.tar.gz,jdk-7u79-linux-x64.tar.gz 上传到目录/home/zwl/Tomcat/命令下 因为Tomcat运 ...
- [团队项目]----Math Calculator
团队项目 ----Math Calculator 任务: 1.每个团队从Github上fork这个项目的源代码 https://github.com/RABITBABY/We-have-bing 2. ...