混合果汁 bzoj-5343 Ctsc-2018

题目大意:给定$n$中果汁,第$i$种果汁的美味度为$d_i$,每升价格为$p_i$,每次最多添加$l_i$升。现在要求用这$n$中果汁调配出$m$杯混合果汁。第$j$杯混合果汁的要求是总价格不多余$g_j$,总体积不小于$L_j$且美味度最大。一杯混合果汁的美味度为所有添加的果汁的美味度的最小值。求$m$杯混合果汁的美味度之和的最大值。

注释:$1\le n,m,d_i,p_i,l_i\le 10^5$,$1\le g_i,L_i\le 10^{18}$。


想法

显然每种混合果汁之间是独立的。

对于每一个询问,我们二分答案美味度。

这样的话所有比$mid$大的果汁随便选,满足询问条件。

我们判断当前的$mid$是否合法,其实就是判断一下组成$L_j$最少需要多少钱。

正确的选择肯定是选美味度大于$mid$中最便宜的,取到上限然后取第二便宜的。

这样的话我们既需要维护美味度序列,还需要保证价格递增。这是二维的,显然想到树套树。

其实如果只有两维的话主席树是完全可以胜任的。

进而我们把果汁按照美味度排序,在这个序列上以价格为权值建立主席树即可。

检验就是把主席树$mid$到后面这段权值线段树取出来。每次取最便宜的操作就相当于在权值线段树上二分即可。

Code:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <vector>
using namespace std; typedef long long ll;
const int N=1e5+5;
inline char nc() {static char *p1,*p2,buf[100000]; return (p1==p2)&&(p2=(p1=buf)+fread(buf,1,10000,stdin),p1==p2)?EOF:*p1++;}
ll rd() {ll x=0; char c=nc(); while(!isdigit(c)) c=nc(); while(isdigit(c)) x=(x<<3)+(x<<1)+(c^48),c=nc(); return x;}
ll g,L;
int n,m,md,mp,tot;
int rt[N],ls[N*20],rs[N*20];
ll s[N*20],sz[N*20],sum[N];
struct node{int p,l;};
vector<node>t[N];
void update(int &x,int l,int r,int k,int v)
{
sz[++tot]=sz[x]+v;
s[tot]=s[x]+1ll*k*v;
ls[tot]=ls[x]; rs[tot]=rs[x]; x=tot;
if(l==r)return;int mid=(l+r)>>1;
if(k<=mid) update(ls[x],l,mid,k,v);
else update(rs[x],mid+1,r,k,v);
}
ll query(int x,int l,int r,ll k)
{
if(l==r) return l*k;
int mid=(l+r)>>1;
if(k<=sz[ls[x]])return query(ls[x],l,mid,k);
return s[ls[x]]+query(rs[x],mid+1,r,k-sz[ls[x]]);
}
bool check(int mid)
{
if(sum[mid]<L)return 0;
return query(rt[mid],1,mp,L)<=g;
}
int solve()
{
int l=0,r=md,ans=-1;
while(l<=r)
{
int mid=(l+r)>>1;
if(check(mid))ans=mid,l=mid+1;
else r=mid-1;
}
return ans;
}
int main()
{
n=rd(),m=rd();
for(int i=1;i<=n;i++)
{
int d=rd(),p=rd(),l=rd();
t[d].push_back((node){p,l});
md=max(md,d); mp=max(mp,p);
}
for(int i=md;i>=0;i--)
{
rt[i]=rt[i+1]; sum[i]=sum[i+1];
for(int j=0,k=t[i].size();j<k;j++)
{
update(rt[i],1,mp,t[i][j].p,t[i][j].l);
sum[i]+=t[i][j].l;
}
}
for(int i=1;i<=m;i++)
{
g=rd(),L=rd();
printf("%d\n",solve());
}
return 0;
}

小结:好题好题。本来是练习整体二分结果做成了主席树。

[bzoj5343][Ctsc2018]混合果汁_二分答案_主席树的更多相关文章

  1. BZOJ5343 [Ctsc2018]混合果汁 【二分 + 主席树】

    题目链接 BZOJ5343 题解 明显要二分一下美味度,然后用尽量少的价格去购买饮料,看看能否买到\(L\)升,然后看看能否控制价格在\(g\)内 尽量少的价格,就优先先选完便宜的饮料,由于询问的是一 ...

  2. [bzoj1614][Usaco2007Jan]Telephone Lines 架设电话线_二分答案_最短路

    Telephone Lines bzoj-1614 Usaco-2007Jan 题目大意:给你一个n个点m条边的带边权无向图,求最短路.可以选取k条边免费. 注释:$1\le n\le 10^3$,$ ...

  3. [校内模拟赛T3]火花灿灿_二分答案_组合数学_贪心

    火花灿灿 题目: 数据范围: 题解: 这个题真的是个神仙题. 我们对于每块石头维护一个$01$串. 这个$01$串的长度是操作次数. 如果$01$串的当前位是$1$,表示这次操作中当前石子被划分到了贡 ...

  4. BZOJ 1305: [CQOI2009]dance跳舞 网络最大流_二分答案_建模

    Description 一次舞会有n个男孩和n个女孩.每首曲子开始时,所有男孩和女孩恰好配成n对跳交谊舞.每个男孩都不会和同一个女孩跳两首(或更多)舞曲.有一些男孩女孩相互喜欢,而其他相互不喜欢(不会 ...

  5. [Agc029C]Lexicographic constraints_进制_二分答案_贪心

    Lexicographic constraints 题目链接:https://atcoder.jp/contests/agc029/tasks/agc029_c 数据范围:略. 题解: 二分是显然的, ...

  6. BZOJ_5343_[Ctsc2018]混合果汁_二分答案+主席树

    BZOJ_5343_[Ctsc2018]混合果汁_二分答案+主席树 题意:给出每个果汁的价格p,美味度d,最多能放的体积l.定义果汁混合后的美味度为果汁的美味度的最小值. m次询问,要求花费不大于g, ...

  7. BZOJ_3613_[Heoi2014]南园满地堆轻絮_二分答案

    BZOJ_3613_[Heoi2014]南园满地堆轻絮_二分答案 Description 小 Z 是 ZRP(Zombies’ Republic of Poetry,僵尸诗歌共和国)的一名诗歌爱好者, ...

  8. BZOJ_4590_[Shoi2015]自动刷题机_二分答案

    BZOJ_4590_[Shoi2015]自动刷题机_二分答案 Description 曾经发明了信号增幅仪的发明家SHTSC又公开了他的新发明:自动刷题机--一种可以自动AC题目的神秘装置.自动 刷题 ...

  9. BZOJ_1044_[HAOI2008]木棍分割_二分答案+DP+单调队列

    BZOJ_1044_[HAOI2008]木棍分割_二分答案+DP Description 有n根木棍, 第i根木棍的长度为Li,n根木棍依次连结了一起, 总共有n-1个连接处. 现在允许你最多砍断m个 ...

随机推荐

  1. ES之各种运算符,for、while、do while 、switch case循环

    运算符优先级: 在所有的运算符中,括号的优先级最高,赋值符号的优先级最低. 小括号 > 计算运算符 > 比较运算符 > 逻辑运算符 > 赋值符号———————————————— ...

  2. 【数据分析 R语言实战】学习笔记 第三章 数据预处理 (下)

    3.3缺失值处理 R中缺失值以NA表示,判断数据是否存在缺失值的函数有两个,最基本的函数是is.na()它可以应用于向量.数据框等多种对象,返回逻辑值. > attach(data) The f ...

  3. Android Studio 打包APK时,出现3个或多个APK

    Android Studio 打包APK时,原来只会出现一个apk,结果现在出现3个apk,仔细检查了一下项目文件发现: Android Studio 的 buid.gradle文件里有个配置项被更改 ...

  4. JAVA 学习笔记 - 反射机制

    1.   JAVA反射机制的概念 2. 怎样实例化一个 Class对象 Class.forName(包名.类名); 对象.getClass(); 类.class; ================== ...

  5. laravel easywechat服务器故障问题

    该公众号提供的服务出现故障,请稍后再试 laravel的 csrf,因为laravel框架自带了这个,微信请求肯定没有这个,所以不成功!所以你要么关了csrf,要么,把微信请求的这个地址放在设置外! ...

  6. CAD绘制固定矩形标注(网页版)

    js中实现代码说明: function DoFixRectComment() { var ent = mxOcx.DrawCustomEntity("TestMxCustomEntity&q ...

  7. 一篇文章告你python能做什么,该不该学?好不好学?适不适合学?

    一.python好学吗?简单吗?容易学吗?没有编程的领取能学吗? 最近有很多小伙伴都在问我这些问题.在这里,我想说,python非常简单易学. 1,简单, Python 非常易于读写,开发者可以把更多 ...

  8. ORA-28000: the account is locked-详细解决方案

    运行-->cmd-->sqlplus /nolog conn system/orcl(或预设的密码) alter user scott identified by tiger(或预设密码) ...

  9. jquery.guide.js 新手指引

    /*! * by xyb * 新版上线时候的黑色半透明镂空遮罩指引效果实现jQuery小插件 * 兼容到IE8+ * MIT使用协议,使用时候保留版权 * */ $.guide = function ...

  10. git命令初级

    git是开源的分布式版本控制系统,分布式主要区别于集中式代表CVS(Concurrent Version System,遵从C/S架构,同步比较笨拙.)和SVN(Subversion),linux开发 ...