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且问的次数也 ...
随机推荐
- RMAN命令
一.启动.关闭数据库 在RMAN中执行关闭和启动数据库的命令与SQL环境下一模一样.当然,在执行之前,你需要先连接到目标数据库,如例: C:\Documents and Settings\Admini ...
- AR 应收 表
AR 应收 应收事务处理相关表 SELECT * FROM ar.ar_batches_all; --事务处理批 SELECT * FROM ar.ra_custom ...
- [sinatra] Just Do It: Learn Sinatra, Part One Darren Jones
1. Install sinatra gem gem install sinatra --no-ri --no-rdoc 2. Basic App #!/usr/bin/ruby require 's ...
- React快速入门
目录: 简介 Hello React! 虚拟DOM React组件 轮子来了:JSX 使用JSX 简介 React是Facebook开源的一个用于构建用户界面的Javascript库,已经 应用于Fa ...
- 图像处理控件ImageGear for .NET教程如何为应用程序 添加DICOM功能(2)
在前面的一些关于图像处理控件ImageGear for .NET文章<图像处理控件ImageGear for .NET教程: 添加DICOM功能(1)>中讲解了如何对应用程序添加DICOM ...
- struts2 笔记01 登录、常用配置参数、Action访问Servlet API 和设置Action中对象的值、命名空间和乱码处理、Action中包含多个方法如何调用
Struts2登录 1. 需要注意:Struts2需要运行在JRE1.5及以上版本 2. 在web.xml配置文件中,配置StrutsPrepareAndExecuteFilter或FilterDis ...
- UIScrollView的滚动位置设置
1.如果手动设置滚动异常,可以从最小值到最大值,极限调试.最小值取一个,中间值取n个,最大值取一个.
- Java生产者消费者模型
在Java中线程同步的经典案例,不同线程对同一个对象同时进行多线程操作,为了保持线程安全,数据结果要是我们期望的结果. 生产者-消费者模型可以很好的解释这个现象:对于公共数据data,初始值为0,多个 ...
- DECODE函数
DECODE函数相当于一条件语句(IF),它将输入数值与函数中的参数列表相比较,根据输入值返回一个对应值.函数的参数列表是由若干数值及其对应结果值组成的若干序偶形式.当然,如果未能与任何一个实参序偶匹 ...
- ios app的真机调试与发布配置
1.打开应用程序—>[钥匙串访问]—>[证书助理]—>[从证书办法机构请求证书] 2.在[用户电子邮件地址]填入apple账户用的邮箱,选择[存储到磁盘],点击[继续],会在 ...