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且问的次数也 ...
随机推荐
- Java -verbose:gc 命令
Java -verbose:gc 中参数-verbose:gc 表示输出虚拟机中GC的详细情况. [Full GC 168K->97K(1984K), 0.0253873 secs] 解读如 ...
- clock gating and PLL
一个gating的clock是指:clock network除了包含inverter和buffer外,还有其他logic. PrimeTime会自动的对gating input进行setup和hold ...
- .net web弹出对话框
Page.ClientScript.RegisterStartupScript(this.GetType(), "", "<script>alert('请输入 ...
- android 应用架构随笔四(View、ViewGroup)
View表示了用户界面的基本构建模块. 一个View占用了屏幕上的一个矩形区域并且负责界面绘制和事件处理.手机屏幕上所有看得见摸得着的都是View. Activity是四大组件中唯一一个用来和用户进行 ...
- 【python cookbook】【数据结构与算法】6.在字典中将键映射到多个值上
问题:一个能将键(key)映射到多个值的字典(即所谓的一键多值字典[multidict]) 解决方案:如果想让键映射到多值,需要将这多个值保持到另一个容器如列表或集合中: >>> d ...
- jquery通过name属性取值的方法
jquery通过name属性取值的方法//$("input[name='imgtitle']").val();//这个只能取到第一个的值//通过each函数取得所有input的值v ...
- history and its relevant variables in Linux/GNU and Mac OS history命令以及相关环境变量
对于Terminalor们,history命令并不陌生,什么!n, !!更是很常用的,而且您在命令行敲的cmds是默认保存在/home/$USER/.bash_history(linux) /User ...
- nginx+tomcat负载均衡+动静分离+redis集中管理session
1.服务器A安装ng,服务器B.C安装tomcat: 2.服务器A建立/data/www目录,用于发布静态文件: 3.ng无动静分离配置: user root root; worker_process ...
- 【jQuery UI 1.8 The User Interface Library for jQuery】.学习笔记.3.创建控件
像jQuery提供 fn.extend() 方法从而可以简单地创建插件一样,jQuery UI也提供了机制使得创造插件变得简单,也确保了公共API功能在新的插件中被保留. 1.首先,创建一个名为 j ...
- shell获取目录下最新的文件,文件是以日期命名
如果你为每个文件按日期命名的格式都一致的话,那么 "ls -l" 命令列出的文件列表就是默认按文件名称(日期先后)排序的.那么最后一个就是最新的,文件名可以用以下方式获取.file ...