分四种情况讨论:a,b>=0

a,b<0

a>=0,b<0

a<0,b>=0

然后每次检验是否进入一个矩形框 或者 是否直接利用这个矩形框的答案 仅仅利用两个对角的坐标进行更新即可。

#include<cstdio>
#include<cmath>
#include<algorithm>
using namespace std;
typedef long long ll;
#define N 50001
#define INF 2147483647
#define KD 2//ά¶ÈÊý
int qp[KD];
ll lim;
int n,root,m;
bool dn;
struct Node
{
int minn[KD],maxx[KD],p[KD],w;
int ch[2];
ll sumv;
void Init()
{
for(int i=0;i<KD;++i)
minn[i]=maxx[i]=p[i];
sumv=(ll)w;
}
}T[N];
void Update(int rt)
{
for(int i=0;i<2;++i)
if(T[rt].ch[i])
{
T[rt].sumv+=T[T[rt].ch[i]].sumv;
for(int j=0;j<KD;++j)
{
T[rt].minn[j]=min(T[rt].minn[j],T[T[rt].ch[i]].minn[j]);
T[rt].maxx[j]=max(T[rt].maxx[j],T[T[rt].ch[i]].maxx[j]);
}
}
}
bool operator < (const Node &a,const Node &b){return a.p[dn]<b.p[dn];}
int Buildtree(int l=1,int r=n,bool d=0)
{
dn=d;
int m=(l+r>>1);
nth_element(T+l,T+m,T+r+1);
T[m].Init();
if(l!=m) T[m].ch[0]=Buildtree(l,m-1,d^1);
if(m!=r) T[m].ch[1]=Buildtree(m+1,r,d^1);
Update(m);
return m;
}
ll ans;
void Query0(int rt=root)//a>0,b>0
{
if((ll)T[rt].p[0] * (ll)qp[0] + (ll)T[rt].p[1] * (ll)qp[1] < lim)
ans+=(ll)T[rt].w;
for(int i=0;i<2;++i)
if(T[rt].ch[i] &&
(ll)T[T[rt].ch[i]].minn[0] * (ll)qp[0] +
(ll)T[T[rt].ch[i]].minn[1] * (ll)qp[1] < lim)
{
if((ll)T[T[rt].ch[i]].maxx[0] * (ll)qp[0] +
(ll)T[T[rt].ch[i]].maxx[1] * (ll)qp[1] < lim)
ans+=T[T[rt].ch[i]].sumv;
else
Query0(T[rt].ch[i]);
}
}
void Query1(int rt=root)//a>0,b<0
{
if((ll)T[rt].p[0] * (ll)qp[0] + (ll)T[rt].p[1] * (ll)qp[1] < lim)
ans+=(ll)T[rt].w;
for(int i=0;i<2;++i)
if(T[rt].ch[i] &&
(ll)T[T[rt].ch[i]].minn[0] * (ll)qp[0] +
(ll)T[T[rt].ch[i]].maxx[1] * (ll)qp[1] < lim)
{
if((ll)T[T[rt].ch[i]].maxx[0] * (ll)qp[0] +
(ll)T[T[rt].ch[i]].minn[1] * (ll)qp[1] < lim)
ans+=T[T[rt].ch[i]].sumv;
else
Query1(T[rt].ch[i]);
}
}
void Query2(int rt=root)//a<0,b>0
{
if((ll)T[rt].p[0] * (ll)qp[0] + (ll)T[rt].p[1] * (ll)qp[1] < lim)
ans+=(ll)T[rt].w;
for(int i=0;i<2;++i)
if(T[rt].ch[i] &&
(ll)T[T[rt].ch[i]].maxx[0] * (ll)qp[0] +
(ll)T[T[rt].ch[i]].minn[1] * (ll)qp[1] < lim)
{
if((ll)T[T[rt].ch[i]].minn[0] * (ll)qp[0] +
(ll)T[T[rt].ch[i]].maxx[1] * (ll)qp[1] < lim)
ans+=T[T[rt].ch[i]].sumv;
else
Query2(T[rt].ch[i]);
}
}
void Query3(int rt=root)//a<0,b<0
{
if((ll)T[rt].p[0] * (ll)qp[0] + (ll)T[rt].p[1] * (ll)qp[1] < lim)
ans+=(ll)T[rt].w;
for(int i=0;i<2;++i)
if(T[rt].ch[i] &&
(ll)T[T[rt].ch[i]].maxx[0] * (ll)qp[0] +
(ll)T[T[rt].ch[i]].maxx[1] * (ll)qp[1] < lim)
{
if((ll)T[T[rt].ch[i]].minn[0] * (ll)qp[0] +
(ll)T[T[rt].ch[i]].minn[1] * (ll)qp[1] < lim)
ans+=T[T[rt].ch[i]].sumv;
else
Query3(T[rt].ch[i]);
}
}
int main()
{
// freopen("bzoj2850.in","r",stdin);
// freopen("bzoj2716.out","w",stdout);
scanf("%d%d",&n,&m);
for(int i=1;i<=n;++i)
scanf("%d%d%d",&T[i].p[0],&T[i].p[1],&T[i].w);
Buildtree();
root=(1+n>>1);
for(int i=1;i<=m;++i)
{
ans=0;
scanf("%d%d%lld",&qp[0],&qp[1],&lim);
if(qp[0]>=0 && qp[1]>=0)
Query0();
else if(qp[0]>=0 && qp[1]<0)
Query1();
else if(qp[0]<0 && qp[1]>=0)
Query2();
else
Query3();
printf("%lld\n",ans);
}
return 0;
}

【kd-tree】bzoj2850 巧克力王国的更多相关文章

  1. Bzoj2850 巧克力王国

    Time Limit: 60 Sec  Memory Limit: 512 MBSubmit: 505  Solved: 204 Description 巧克力王国里的巧克力都是由牛奶和可可做成的.但 ...

  2. bzoj2850巧克力王国

    巧克力王国 Time Limit: 60 Sec  Memory Limit: 512 MBSubmit: 861  Solved: 325[Submit][Status][Discuss] Desc ...

  3. [bzoj2850]巧克力王国_KD-Tree

    巧克力王国 bzoj-2850 题目大意:给出n块巧克力,每块巧克力都有自己的两个参数x和y和本身的价值val,询问:m个人,每个人有两个系数和一个限度a,b,和c.求所有ax+by<=c的巧克 ...

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

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

  5. 【BZOJ2850】巧克力王国 KDtree

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

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

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

  7. 洛谷P4475 巧克力王国

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

  8. 初涉k-d tree

    听说k-d tree是一个骗分的好东西?(但是复杂度差评??? 还听说绍一的kdt常数特别小? KDT是什么 KDT的全称是k-degree tree,顾名思义,这是一种处理多维空间的数据结构. 例如 ...

  9. BZOJ2820 - 巧克力王国

    原题链接 Description 给出个二维平面上的点,第个点为,权值为.接下来次询问,给出,求所有满足的点的权值和. Solution 对于这个点建一棵k-d树,子树维护一个子树和. 如果子树所代表 ...

随机推荐

  1. visudo 使用摘记

    1. sudo <command> 免输入密码.root 运行 visudo. 添加命令行:<username>    <hostname>=NOPASSWD: & ...

  2. .NET使用一般处理程序生成验证码

    运行的效果图: HTML的代码: <head> <script type="text/javascript"> function changeCode() ...

  3. 创建线程方式-pthread

    *:first-child { margin-top: 0 !important; } body > *:last-child { margin-bottom: 0 !important; } ...

  4. spring定时器设置(转自:http://my.oschina.net/LvSantorini/blog/520049)

    转自:http://my.oschina.net/LvSantorini/blog/520049<!-- MessageRequestTask类中包含了msgRequest方法,用于执行定时任务 ...

  5. Flex 加载tiff

    gis系统常常要加载tiff,因为好多土地证书,各种文件都是扫描件,如果你是用as来写的前台,怎么加载呢,顺便说下用插件AlternaTIFF也是可以得不过浏览器加载这么多插件是不太好的. 首先TIF ...

  6. AngularJs 简单实现全选,多选操作

    很多时候我们在处理CURD(增删改查)的时候需要实现批量操作数据,这时候就必须使用多选操作. Angular 中实现如下(当然还有很多种比笔者写的更好的方法,这里只是简单的实现.) demo 演示地址 ...

  7. coroSync packmarker

    CoroSync+Pacemaker实现web高可用 2015-04-12 23:38:19 标签:CoroSync pacemaker 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 ...

  8. Rserve, java调用R源文件

    Rserve安装和加载: install.packages("Rserve") library("Rserve") Rserve()   java调用: REn ...

  9. Oracle 查询库中所有表名、字段名、字段名说明,查询表的数据条数、表名、中文表名、

    查询所有表名:select t.table_name from user_tables t;查询所有字段名:select t.column_name from user_col_comments t; ...

  10. empty isset array_key_exists 的区别

    empty: 参数为0或为NULL时(如上面列子),empty均返回TRUE,详细情况可以参见empty官方手册 isset: 参数为NULL时,返回FALSE,0与NULL在PHP中是有区别的,is ...