https://www.luogu.org/problemnew/show/P4602

https://loj.ac/problem/2555

https://www.lydsy.com/JudgeOnline/problem.php?id=5343

小 R 热衷于做黑暗料理,尤其是混合果汁。

商店里有 n 种果汁,编号为 0,1,2,...,n−1。i 号果汁的美味度是 di,每升价格为 pi。小 R 在制作混合果汁时,还有一些特殊的规定,即在一瓶混合果汁中,i 号果汁最多只能添加 li 升。

现在有 m 个小朋友过来找小 R 要混合果汁喝,他们都希望小 R 用商店里的果汁制作成一瓶混合果汁。其中,第 j 个小朋友希望他得到的混合果汁总价格不大于 gj,体积不小于 Lj。在上述这些限制条件下,小朋友们还希望混合果汁的美味度尽可能地高,一瓶混合果汁的美味度等于所有参与混合的果汁的美味度的最小值。请你计算每个小朋友能喝到的最美味的混合果汁的美味度。

比较简单……前提是不会把题看成“果汁美味度=美味度之和”。

这样一来我们先对美味度排序,然后二分答案,就可以知道我们只可以取k~n的果汁,然后判断是否可行即可。

贪心的思路:我们按照p从小到大取果汁是最优的。

主席树显然可以胜任这个工作。

#include<cmath>
#include<cstdio>
#include<cctype>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
typedef long long ll;
const int N=1e5+;
inline ll read(){
ll X=,w=;char ch=;
while(!isdigit(ch)){w|=ch=='-';ch=getchar();}
while(isdigit(ch))X=(X<<)+(X<<)+(ch^),ch=getchar();
return w?-X:X;
}
struct juice{
int d,p,l;
}a[N];
struct tree{
int l,r;
ll v,s;
}tr[N*];
int n,m,t,pos[N],rt[N],pool;
inline bool cmp(juice a,juice b){
return a.d<b.d;
}
inline void insert(int y,int &x,int l,int r,int p,int v){
tr[x=++pool]=tr[y];
tr[x].v+=(ll)p*v;tr[x].s+=v;
if(l==r)return;
int mid=(l+r)>>;
if(p<=mid)insert(tr[y].l,tr[x].l,l,mid,p,v);
else insert(tr[y].r,tr[x].r,mid+,r,p,v);
}
inline ll query(int nl,int nr,int l,int r,ll p){
if(l==r)return min(p/l,tr[nr].s-tr[nl].s);
ll delta=tr[tr[nr].l].v-tr[tr[nl].l].v;
ll tmp=tr[tr[nr].l].s-tr[tr[nl].l].s;
int mid=(l+r)>>;
if(delta>p)return query(tr[nl].l,tr[nr].l,l,mid,p);
else return tmp+query(tr[nl].r,tr[nr].r,mid+,r,p-delta);
}
ll G,L;
bool pan(int k){
ll tmp=query(rt[k-],rt[n],,1e5,G);
return tmp>=L;
}
ll solve(int l,int r){
while(l<r){
int mid=(l+r+)>>;
if(pan(pos[mid]))l=mid;
else r=mid-;
}
return pan(pos[l])?a[pos[l]].d:-;
}
int main(){
n=read(),m=read();
for(int i=;i<=n;i++)
a[i].d=read(),a[i].p=read(),a[i].l=read();
sort(a+,a+n+,cmp);
for(int i=;i<=n;i++){
if(a[pos[t]].d!=a[i].d)pos[++t]=i;
insert(rt[i-],rt[i],,1e5,a[i].p,a[i].l);
}
for(int i=;i<=m;i++){
G=read(),L=read();
printf("%lld\n",solve(,t));
}
return ;
}

+++++++++++++++++++++++++++++++++++++++++++

+本文作者:luyouqi233。               +

+欢迎访问我的博客:http://www.cnblogs.com/luyouqi233/ +

+++++++++++++++++++++++++++++++++++++++++++

最新文章

  1. 学习 AppFuse
  2. echo(),print(),print_r(),var_dump的区别?
  3. HDU 4833 Best Financing(DP)(2014年百度之星程序设计大赛 - 初赛(第二轮))
  4. VirtualBox启动虚拟机报错0x80004005
  5. Reorder List [LeetCode]
  6. C++容器和算法
  7. mysql datestamp坑
  8. [实验]通过内核Patch去掉iOS-v4.3.3的沙盒特性
  9. Spark Standalone Mode
  10. 基于模糊聚类和最小割的层次化网格分割算法(Hierarchical Mesh Decomposition)
  11. Bat脚本自动卸载软件-静默执行
  12. Python终端输出打印彩色字体的方法
  13. ubuntu 16.04上 mysql 5.7 安装笔记
  14. format() expandtabs() 输入表格数据
  15. java thread 线程40个问题汇总
  16. 第八周--Linux中进程调度与进程切换的过程
  17. gentoo wireshark 安装
  18. HDU 1176 免费馅饼 DP类似数塔题
  19. 关于maven工程打jar的问题
  20. Windows环境下为PHP5.6安装redis扩展和memcached扩展

热门文章

  1. shell 批量压缩指定目录及子目录内图片的方法
  2. libevent学习四(Working with events)
  3. hdu1969Pie(根据体积二分,分馅饼)
  4. Qt-QML-Connections,接受组件信号
  5. lesson 23 one man&#39;s meat is another man&#39;s poison
  6. ES6 之 let / const
  7. struts2之form标签theme属性详解
  8. Thunder团队第一周 - Scrum会议7
  9. LintCode-56.两数之和
  10. LintCode-68.二叉树的后序遍历