传送门

首先可以把约束条件看成一条直线,然后每个巧克力看成一个点,求给定区域内的点权和

用KDTree,每次判断一下当前矩形是否整个都在里面或都在外面,是的话直接返回,否则的话递归

注意,必须该矩形四个顶点都在里面或外面才能判断

  1. //minamoto
  2. #include<bits/stdc++.h>
  3. #define R register
  4. #define ll long long
  5. #define fp(i,a,b) for(R int i=a,I=b+1;i<I;++i)
  6. #define fd(i,a,b) for(R int i=a,I=b-1;i>I;--i)
  7. #define go(u) for(int i=head[u],v=e[i].v;i;i=e[i].nx,v=e[i].v)
  8. template<class T>inline bool cmin(T&a,const T&b){return a>b?a=b,1:0;}
  9. template<class T>inline bool cmax(T&a,const T&b){return a<b?a=b,1:0;}
  10. using namespace std;
  11. char buf[1<<21],*p1=buf,*p2=buf;
  12. inline char getc(){return p1==p2&&(p2=(p1=buf)+fread(buf,1,1<<21,stdin),p1==p2)?EOF:*p1++;}
  13. ll read(){
  14. R ll res,f=1;R char ch;
  15. while((ch=getc())>'9'||ch<'0')(ch=='-')&&(f=-1);
  16. for(res=ch-'0';(ch=getc())>='0'&&ch<='9';res=res*10+ch-'0');
  17. return res*f;
  18. }
  19. char sr[1<<21],z[20];int C=-1,Z=0;
  20. inline void Ot(){fwrite(sr,1,C+1,stdout),C=-1;}
  21. void print(R ll x){
  22. if(C>1<<20)Ot();if(x<0)sr[++C]='-',x=-x;
  23. while(z[++Z]=x%10+48,x/=10);
  24. while(sr[++C]=z[Z],--Z);sr[++C]='\n';
  25. }
  26. const int N=50005;
  27. struct node{int v[2],mn[2],mx[2],w,l,r;ll sum;}tr[N];
  28. int n,m,K,rt,a,b;ll c;
  29. inline bool operator <(const node &a,const node &b){return a.v[K]<b.v[K];}
  30. void upd(int p){
  31. int l=tr[p].l,r=tr[p].r;
  32. fp(i,0,1){
  33. tr[p].mn[i]=tr[p].mx[i]=tr[p].v[i];
  34. if(l)cmin(tr[p].mn[i],tr[l].mn[i]),cmax(tr[p].mx[i],tr[l].mx[i]);
  35. if(r)cmin(tr[p].mn[i],tr[r].mn[i]),cmax(tr[p].mx[i],tr[r].mx[i]);
  36. }tr[p].sum=tr[l].sum+tr[r].sum+tr[p].w;
  37. }
  38. int build(int l,int r,int k){
  39. K=k;int mid=(l+r)>>1;nth_element(tr+l,tr+mid,tr+r+1);
  40. if(l<mid)tr[mid].l=build(l,mid-1,k^1);
  41. if(mid<r)tr[mid].r=build(mid+1,r,k^1);
  42. upd(mid);return mid;
  43. }
  44. inline bool in(int x,int y){return 1ll*a*x+1ll*b*y<c;}
  45. ll query(int p){
  46. if(!p)return 0;
  47. if(in(tr[p].mx[0],tr[p].mx[1])&&in(tr[p].mn[0],tr[p].mn[1])
  48. &&in(tr[p].mn[0],tr[p].mx[1])&&in(tr[p].mx[0],tr[p].mn[1]))return tr[p].sum;
  49. ll res=0;if(!in(tr[p].mn[0],tr[p].mn[1])&&!in(tr[p].mx[0],tr[p].mx[1])
  50. &&!in(tr[p].mn[0],tr[p].mx[1])&&!in(tr[p].mx[0],tr[p].mn[1]))return 0;
  51. if(in(tr[p].v[0],tr[p].v[1]))res+=tr[p].w;
  52. res+=query(tr[p].l)+query(tr[p].r);return res;
  53. }
  54. int main(){
  55. // freopen("testdata.in","r",stdin);
  56. n=read(),m=read();
  57. fp(i,1,n)tr[i].v[0]=read(),tr[i].v[1]=read(),tr[i].w=read();
  58. rt=build(1,n,0);
  59. while(m--)a=read(),b=read(),c=read(),print(query(rt));
  60. return Ot(),0;
  61. }

P4475 巧克力王国(KDTree)的更多相关文章

  1. 洛谷 P4475 巧克力王国 解题报告

    P4475 巧克力王国 题目描述 巧克力王国里的巧克力都是由牛奶和可可做成的.但是并不是每一块巧克力都受王国人民的欢迎,因为大家都不喜欢过于甜的巧克力. 对于每一块巧克力,我们设 \(x\) 和 \( ...

  2. 洛谷P4475 巧克力王国

    洛谷P4475 巧克力王国 题目描述 巧克力王国里的巧克力都是由牛奶和可可做成的. 但是并不是每一块巧克力都受王国人民的欢迎,因为大家都不喜欢过于甜的巧克力. 对于每一块巧克力,我们设 x 和 y 为 ...

  3. 【BZOJ2850】巧克力王国 [KD-tree]

    巧克力王国 Time Limit: 60 Sec  Memory Limit: 512 MB[Submit][Status][Discuss] Description 巧克力王国里的巧克力都是由牛奶和 ...

  4. 【BZOJ2850】巧克力王国 KDtree

    [BZOJ2850]巧克力王国 Description 巧克力王国里的巧克力都是由牛奶和可可做成的.但是并不是每一块巧克力都受王国人民的欢迎,因为大家都不喜 欢过于甜的巧克力.对于每一块巧克力,我们设 ...

  5. BZOJ 2850: 巧克力王国 KDtree + 估价函数

    Code: #include<bits/stdc++.h> #define maxn 100000 #define inf 1000000008 #define mid ((l+r)> ...

  6. p4475 巧克力王国

    传送门 分析 我们多维护一个值,代表某个点子树中所有点的权值和 于是如果某个点它的min和max乘a(/b)的值小于范围则直接把整个子树都加进去 估价函数就是这个点的子树中的理论最小值 代码 #inc ...

  7. bzoj 2850 巧克力王国——KDtree

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2850 改一下估价即可.判断子树能否整个取或者是否整个不能取,时间好像就能行了? 因为有负数, ...

  8. P4475 巧克力王国 k-d tree

    思路:\(k-d\ tree\) 提交:2次 错因:\(query\)时有一个\(mx\)误写成\(mn\)窝太菜了. 题解: 先把\(k-d\ tree\)建出来,然后查询时判一下整个矩形是否整体\ ...

  9. KD-tree 专题「Hide and Seek · 巧克力王国」

    Lockey的瞎理解 抄了一遍板子又水了俩题,感觉对KD-tree 稍稍理解了一点儿,唠叨一下(二维的KD-tree),如有错误请指出(Lockey 洗脸恭听) 普通平衡树维护的是一维的序列,但对于二 ...

随机推荐

  1. Spring错误异常重试框架guava-retrying

    官网:https://github.com/rholder/guava-retrying Maven:https://mvnrepository.com/artifact/com.github.rho ...

  2. how to read openstack code: service plugin

    We have learned core plugin, service plugin and extension in last post. Now let`s review: Core Plugi ...

  3. json解析bug之ERROR ExceptionController:185 - not close json text, token : :

    错误:ERROR ExceptionController:185 - not close json text, token : : 原因:json数据格式有误.!我的错误是,缺少了一个包括json数据 ...

  4. Codefoces 436 B. Om Nom and Spiders

    纯属练习JAVA.... B. Om Nom and Spiders time limit per test 3 seconds memory limit per test 256 megabytes ...

  5. Binder IPC的权限控制

    PS:个人理解:当进程1通过Binder调用组件2时,会将进程1的pid及uid赋给组件2,并检测进程1的pid及uid是否有权限调用组件2.而后组件2需要调用组件3,此时组件2保存的pid及uid为 ...

  6. SQLite Expert表分离和解决SQLite Expert删除表后大小不变的问题

    最后要使用到号码归属地的查询,在网上找到一个数据库文件.大小有12M多,压缩成zip也有1.9M,这样对于一个apk的大小非常不利,后来看了一下数据库的内容,发现有非常多冗余.特别是中文字符占用非常大 ...

  7. 成员函数指针 C++ FAQ LITE — Frequently Asked Questions

    http://www.sunistudio.com/cppfaq/pointers-to-members.html C++ FAQ LITE — Frequently Asked Questions ...

  8. Idea 13 新建maven项目

    1.此时生成的maven项目没有web文件夹 file→New Project→Maven→Next→GID.AID (NewDemo)→Next→ProjectName(NewDemo)→Finis ...

  9. HDFS的体系架构

    通过对Hadoop分布式计算平台最核心的分布式文件系统HDFS.MapReduce处理过程,以及数据仓库工具Hive和分布式数据库Hbase的介绍.基本涵盖了Hadoop分布式平台的全部技术核心. H ...

  10. 访问某类型的元数据的方式-TypeDescriptor 类

    .NET Framework 提供了两种访问某类型的元数据的方式:通过 System.Reflection 命名空间中提供的反射 API,以及通过 TypeDescriptor 类.反射是可用于所有类 ...