主席树+二分 p4602
题意:给出每一种果汁的美味度,价格,升数;
m个询问,每个询问给出最高上限的钱g,以及给出最少的w
意思是,最多用g的钱去买最少l的果汁,问能得到的最大美味度;
美味度是取所有果汁中美味度的最小值;
所以这道题有:美味度,价格,升数,
一开始想的时候,因为多了一个条件不知道怎么操作,看了题解之后才发现,将其中的美味度拿来二分了;
也就是说,题目中的美味度取值,是二分出来的;
那么如何建树呢?
因为美味度二分,自然建树的时候是拿美味度作为主体;
也就是说,按美味度从小到大建树(小的美味度可以包括大的美味度)
然后价格作为权值,维护 花费和升数;
那么 在最后提问的时候,我们给定一个l,r; 二分他的mid;
如果他的mid二分出来的值符合,则更新;
那么 如何二分呢,我们将钱最为一个条件放入数中去深搜,如果在这个钱的范围内能找到大于等于升数的,就ans=mid,r=mid-1;
否则则反;
#include<cstdio>
#include<algorithm>
#include<string.h>
#include<queue>
using namespace std;
typedef long long ll;
const ll maxn=1e5+;
ll sum[maxn],b[maxn],root[maxn];
struct node
{
ll d,p,l;
}G[maxn];
struct Node
{
ll ln,rn;
ll sum,val;
}tree[maxn<<]; ll cnt;
bool cmp(node a,node b)
{
return a.d>b.d;
}
void update(ll pos,ll &x,ll y,ll l,ll r,ll p,ll k)
{
tree[++cnt]=tree[y];x=cnt;
tree[x].sum+=p*k;
tree[x].val+=k;
if(l==r) return;
ll mid=l+r>>;
if(pos<=mid) update(pos,tree[x].ln,tree[y].ln,l,mid,p,k);
else update(pos,tree[x].rn,tree[y].rn,mid+,r,p,k);
}
ll query(ll root,ll l,ll r,ll limit)
{
if(l==r){
if(tree[root].val*b[l]>=limit) return limit/b[l];
else return tree[root].val;
}
ll mid=l+r>>;
ll left=tree[root].ln,right=tree[root].rn;
if(tree[left].sum>limit) return query(left,l,mid,limit);
else return tree[left].val+query(right,mid+,r,limit-tree[left].sum);
}
int main()
{
ll n,m;
scanf("%lld%lld",&n,&m);
for(ll i=;i<=n;i++){
scanf("%lld%lld%lld",&G[i].d,&G[i].p,&G[i].l);
b[i]=G[i].p;
}
sort(b+,b++n);
ll limit=unique(b+,b++n)-b-;
sort(G+,G++n,cmp);
for(ll i=;i<=n;i++){
sum[i]=sum[i-]+G[i].l;
ll pos=lower_bound(b+,b++limit,G[i].p)-b;
update(pos,root[i],root[i-],,limit,G[i].p,G[i].l);
}
while(m--){
ll g,w;
scanf("%lld%lld",&g,&w);
if(sum[n]<w){
printf("-1\n");
continue;
}
ll left=lower_bound(sum+,sum++n,w)-sum;
ll right=n,ans=-;
while(left<=right){
ll mid=left+right>>;
if(query(root[mid],,limit,g)>=w){
ans=mid;right=mid-;
}
else left=mid+;
}
if(ans==-) printf("-1\n");
else printf("%lld\n",G[ans].d);
}
return ;
}
主席树+二分 p4602的更多相关文章
- 2018湘潭邀请赛C题(主席树+二分)
题目地址:https://www.icpc.camp/contests/6CP5W4knRaIRgU 比赛的时候知道这题是用主席树+二分,可是当时没有学主席树,就连有模板都不敢套,因为代码实在是太长了 ...
- BZOJ.1926.[SDOI2010]粟粟的书架(前缀和 主席树 二分)
题目链接 题意: 在给定矩形区域内找出最少的数,满足和>=k.输出数的个数.两种数据范围. 0~50 注意到(真没注意到...)P[i,j]<=1000,我们可以利用前缀和预处理. num ...
- 计蒜客 38229.Distance on the tree-1.树链剖分(边权)+可持久化线段树(区间小于等于k的数的个数)+离散化+离线处理 or 2.树上第k大(主席树)+二分+离散化+在线查询 (The Preliminary Contest for ICPC China Nanchang National Invitational 南昌邀请赛网络赛)
Distance on the tree DSM(Data Structure Master) once learned about tree when he was preparing for NO ...
- HDU - 4866 主席树 二分
题意:在x轴\([1,X]\)内的上空分布有n个占据空间\([L_i,R_i]\),高度\(D_i\)的线段,射中线段的得分为其高度,每次询问从x轴的\(x\)往上空射的最近k个线段的总得分,具体得分 ...
- POJ 6621: K-th Closest Distance(主席树 + 二分)
K-th Closest Distance Time Limit: 20000/15000 MS (Java/Others) Memory Limit: 524288/524288 K (Jav ...
- HDU6621 K-th Closest Distance HDU2019多校训练第四场 1008(主席树+二分)
HDU6621 K-th Closest Distance HDU2019多校训练第四场 1008(主席树+二分) 传送门:http://acm.hdu.edu.cn/showproblem.php? ...
- 13年山东省赛 Boring Counting(离线树状数组or主席树+二分or划分树+二分)
转载请注明出处: http://www.cnblogs.com/fraud/ ——by fraud 2224: Boring Counting Time Limit: 3 Sec ...
- BZOJ 1926: [Sdoi2010]粟粟的书架(主席树,二分答案)
BZOJ 1926: [Sdoi2010]粟粟的书架(主席树,二分答案) 题意 : 给你一个长为\(R\)宽为\(C\)的矩阵,第\(i\)行\(j\)列的数为\(P_{i,j}\). 有\(m\)次 ...
- bzoj 1926: [Sdoi2010]粟粟的书架 (主席树+二分)
链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1926 题面; 1926: [Sdoi2010]粟粟的书架 Time Limit: 30 Se ...
随机推荐
- CSS-使用CSS样式的方式
1.HTML<!DOCTYPE>声明标签 (1)定义和用法 <!DOCTYPE>声明必须是HTML文档的第一行,位于<html>标签之前. <!DOCTYPE ...
- 搜索字母a或A
Amy觉得英语课实在是无聊至极,他不喜欢听老师讲课. 但是闲着也是闲着,不如做点什么吧?于是他开始数英语书里的字母a和A共出现了多少次. 费了九牛二虎之力终于数完了. 作为一名软件工程专业大学生,他觉 ...
- 前端 form select js处理
1.代码如下 function initializeSelect(data) { var area = $("#ServiceName"); area.find("opt ...
- SimpleDateFormat中YYYYmmDDhhMMss大小写问题-获取不到正确时间以及常见的格式串
1.问题解决: SimpleDateFormat sf = new SimpleDateFormat("YYYYmmDDhhMMss");String transTime = &q ...
- 【Unity|C#】基础篇(7)——属性(Property)/ 索引器(Indexer)
[学习资料] <C#图解教程>(第6章):https://www.cnblogs.com/moonache/p/7687551.html 电子书下载:https://pan.baidu.c ...
- 2019-08-10 纪中NOIP模拟B组
T1 [JZOJ1235] 洪水 题目描述 一天, 一个画家在森林里写生,突然爆发了山洪,他需要尽快返回住所中,那里是安全的. 森林的地图由R行C列组成,空白区域用点“.”表示,洪水的区域用“*”表示 ...
- bzoj 1483
Description N个布丁摆成一行,进行M次操作.每次将某个颜色的布丁全部变成另一种颜色的,然后再询问当前一共有多少段颜色.例如颜色分别为1,2,2,1的四个布丁一共有3段颜色. Input 第 ...
- 图的最短路径算法-- Floyd算法
Floyd算法求的是图的任意两点之间的最短距离 下面是Floyd算法的代码实现模板: ; ; // maxv为最大顶点数 int n, m; // n 为顶点数,m为边数 int dis[maxv][ ...
- MySQL5.5升级至5.7
一.下载免安装MySQL5.7包 下载页面 下载链接 二.替换mysql的安装目录 解压mysql5.7 tar -zxf mysql-5.7.23-linux-glibc2.12-x86_64.ta ...
- ADO.NET中sqlserver和mysql的变量名
因为ADO.NET标配是访问SQL SERVER数据库,那么如果需要访问MySQL数据库,那么ADO.NET五个对象也必须转换. 访问 SQL SERVER 的ADO.NET对象 1.SqlConne ...