【kd-tree】bzoj2850 巧克力王国
分四种情况讨论: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 巧克力王国的更多相关文章
- Bzoj2850 巧克力王国
Time Limit: 60 Sec Memory Limit: 512 MBSubmit: 505 Solved: 204 Description 巧克力王国里的巧克力都是由牛奶和可可做成的.但 ...
- bzoj2850巧克力王国
巧克力王国 Time Limit: 60 Sec Memory Limit: 512 MBSubmit: 861 Solved: 325[Submit][Status][Discuss] Desc ...
- [bzoj2850]巧克力王国_KD-Tree
巧克力王国 bzoj-2850 题目大意:给出n块巧克力,每块巧克力都有自己的两个参数x和y和本身的价值val,询问:m个人,每个人有两个系数和一个限度a,b,和c.求所有ax+by<=c的巧克 ...
- P4475 巧克力王国 k-d tree
思路:\(k-d\ tree\) 提交:2次 错因:\(query\)时有一个\(mx\)误写成\(mn\)窝太菜了. 题解: 先把\(k-d\ tree\)建出来,然后查询时判一下整个矩形是否整体\ ...
- 【BZOJ2850】巧克力王国 KDtree
[BZOJ2850]巧克力王国 Description 巧克力王国里的巧克力都是由牛奶和可可做成的.但是并不是每一块巧克力都受王国人民的欢迎,因为大家都不喜 欢过于甜的巧克力.对于每一块巧克力,我们设 ...
- 【BZOJ2850】巧克力王国 [KD-tree]
巧克力王国 Time Limit: 60 Sec Memory Limit: 512 MB[Submit][Status][Discuss] Description 巧克力王国里的巧克力都是由牛奶和 ...
- 洛谷P4475 巧克力王国
洛谷P4475 巧克力王国 题目描述 巧克力王国里的巧克力都是由牛奶和可可做成的. 但是并不是每一块巧克力都受王国人民的欢迎,因为大家都不喜欢过于甜的巧克力. 对于每一块巧克力,我们设 x 和 y 为 ...
- 初涉k-d tree
听说k-d tree是一个骗分的好东西?(但是复杂度差评??? 还听说绍一的kdt常数特别小? KDT是什么 KDT的全称是k-degree tree,顾名思义,这是一种处理多维空间的数据结构. 例如 ...
- BZOJ2820 - 巧克力王国
原题链接 Description 给出个二维平面上的点,第个点为,权值为.接下来次询问,给出,求所有满足的点的权值和. Solution 对于这个点建一棵k-d树,子树维护一个子树和. 如果子树所代表 ...
随机推荐
- Django views 中 View decorators
decorators(装饰器) 1. require_http_methods 在django.views.decorators.http中,可以用来限制请求的权限. require_http_met ...
- [EventBus源码解析] 订阅者处理消息的四种ThreadMode
前言 在前面,我们探讨了如何在自己的代码中引入EventBus,进行基本的事件分发/监听:对注册观察者与事件发送的过程进行了浅析.从之前的学习中,我们了解到,EventBus一共有4种onEvent方 ...
- Create User - mysql
Create User MariaDB [(none)]> CREATE USER 'DBAdmin'@'%' IDENTIFIED BY 'mypasswd';Query OK, 0 rows ...
- 剑指Offer:面试题24——二叉搜索树的后序遍历序列(java实现)
问题描述: 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则返回true,否则返回false.假设输入的数组的任意两个数字都互不相同. 思路: 1.首先后序遍历的结果是[(左子 ...
- leetcode 160
160. Intersection of Two Linked Lists Write a program to find the node at which the intersection of ...
- Linux系统man查询命令等级及意义
1:用户命令,可由任何人启动的 2:系统调用,由内核提供的函数 3:库函数 4:设备,/dev目录下的特殊文件 5:文件格式描述,例如/etc/passwd 6:游戏 7:杂项,例如宏命令包.惯例等 ...
- Mybatis保存数据时事务问题
今天不小心在sqlplus中用for update ,然后事务没提交,结果在项目中一直保存不进去数据,找了很久发现是sqlplus中的事务没提交,哎,这种问题真得避免啊,一定要细心啊!
- Python 前端之JS
JavaScript由浏览器编译运行 JS的导入方式有两种,一种直接定义,第二种通过src引入:可以存放在<head>头部,但是强烈建议放在<body>的最下面,因为如果你引入 ...
- information_schema系列三(文件,变量)
这个系列的文章主要是为了能够让自己了解MySQL5.7的一些系统表,统一做一下备注和使用,也希望分享出来让大家能够有一点点的受益. 1:FILES 这张表提供了有关在MySQL的表空间中的数据存储的文 ...
- 一个PHP日历程序
<?php //<-------处理通过GET方法提交的变量;开始--------> if($HTTP_GET_VARS[year]=="") { ...