【kd-tree】bzoj2850 巧克力王国

时间:2022-06-16 23:52:58

分四种情况讨论: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. &lbrack;bzoj2850&rsqb;巧克力王国&lowbar;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】巧克力王国 &lbrack;KD-tree&rsqb;

    巧克力王国 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. Redis介绍以及安装(Linux)

    Redis介绍以及安装(Linux) redis是当前比较热门的NOSQL系统之一,它是一个key-value存储系统.和Memcached类似,但很大程度补偿了memcached的不足,它支持存储的 ...

  2. ACdream 1726 A Math game (dfs&plus;二分)

    http://acdream.info/problem?pid=1726 官方题解:http://acdream.info/topic?tid=4246 求n个数里面能不能选一些数出来让它们的和等于k ...

  3. 统一建模语言&lpar;UML&rpar; 版本 2&period;0

    原文: http://www.ibm.com/developerworks/cn/rational/321_uml/ 简介 参考 UML 基础系列的其他文章和教程 UML基础: 统一建模语言简介 UM ...

  4. 实习小白笔记一&lpar;鼠标悬停、获取多选、提交修改、layer页面、单元格文字长度、json、分页、左连接&rpar;

    ①easyui 当鼠标悬停显示单元格信息: $(this).datagrid('doCellTip',{'max-width':'600px','delay':300}); ②jquery 获取che ...

  5. Codeforces Round &num;274 &lpar;Div&period; 2&rpar; --A Expression

    主题链接:Expression Expression time limit per test 1 second memory limit per test 256 megabytes input st ...

  6. 《JS权威指南学习总结--7&period;9 ES5中的数组方法》

    内容要点: ES5中定义了9个新的数组方法来遍历.映射.过滤.检测.简化和搜索数组. 概述:首先,大多数方法的第一个参数接收一个函数,并且对数组的每个元素(或一个元素)调用一次该函数. 如果是稀疏数组 ...

  7. CentOS 7 安装配置 NFS

    CentOS 7  安装配置 NFS 环境 nps 192.168.1.97 client 192.168.1.98 一.yum 安装 yum -y install nfs-utils rpcbind ...

  8. 处理机调度算法&lpar; RR 、HRRF&rpar;

    1. P117页,练习15:最高响应比( HRRF) 2. P119页,练习22(2):时间片轮转( RR ) 3. 现设定采用三级反馈队列调度算法,三个队列分别为0.1和2,对应时间片为2.4.8. ...

  9. js-cookie和session

    ###1.cookie 含义: 存储在访问者的计算机中的变量,即存储在客户端 创建一个cookie /* getCookie方法判断document.cookie对象中是否存有cookie,若有则判断 ...

  10. mysql使用存储过程和event定期删除

    -- 创建存储过程DELIMITER //CREATE PROCEDURE del_data()BEGIN DELETE FROM t_route_status WHERE route_date &l ...