设$x_j$,$y_j$为第$j$天能买的A,B券数量,$f_i$为第$i$天的最大收益。$f_i=\max_{1\le j<i}a_ix_j+b_iy_j$,最大化$f_i$即找一个点$(x_j,y_j)$,使得这个点和斜率$-a_i/b_i$所确定的直线截距最大。平衡树维护凸包即可,按$x$建平衡树,并维护斜率单调递减,判断删点时用叉积比较优越。比一般的CDQ还快,可能是因为凸包的点数不多,所以平衡树的log就比较小。另外就是不加eps理论上也没有问题。

#include<cstdio>
#include<cstdlib>
typedef double real;
const int N=1e5+5;
typedef struct node*ptr;
struct node{
ptr i,j,s,t;real w,x,y;
node(){w=rand();}
}*b,e[N];
void zag(ptr&x){ptr y=x->j;x->j=y->i,y->i=x,x=y;}
void zig(ptr&x){ptr y=x->i;x->i=y->j,y->j=x,x=y;}
void ins(ptr y,ptr&x=b){
if(!x)x=y,x->s?x->s->t=x:0,x->t?x->t->s=x:0;
else if(y->x>x->x)
{ins(y,x->j);if(x->j->w>x->w)zag(x);}
else
{ins(y,x->i);if(x->i->w>x->w)zig(x);}
}
void del(ptr y,ptr&x=b){
if(y->x>x->x)del(y,x->j);
else if(x->x>y->x)del(y,x->i);
else if(!x->i)x=x->j;
else if(!x->j)x=x->i;
else if(x->i->w>x->j->w)zig(x),del(y,x->j);
else zag(x),del(y,x->i);
}
ptr pre(real k,ptr x=b){
ptr y=0;
while(x)k>=x->x?y=x,x=x->j:x=x->i;
return y;
}
ptr suc(real k,ptr x=b){
ptr y=0;
while(x)x->x>=k?y=x,x=x->i:x=x->j;
return y;
}
real slo(ptr s,ptr t){return(s->y-t->y)/(s->x-t->x);}
real cal(ptr x,ptr s,ptr t){
real x1=x->x-s->x,x2=t->x-s->x;
real y1=x->y-s->y,y2=t->y-s->y;
return x1*y2-x2*y1;
}
void upd(ptr x){
if(ptr&y=x->s=pre(x->x))
while(y->s&&cal(x,y->s,y)<=0)
del(y),y=pre(x->x);
if(ptr&y=x->t=suc(x->x))
while(y->t&&cal(x,y,y->t)<=0)
del(y),y=suc(x->x);
if(!x->s||!x->t||cal(x->t,x->s,x)>0)
ins(x);
}
void eq2(real&x,real y){x=x<y?y:x;}
real s,t,r,f;
void sol(real k,ptr x=b){
if(x->s&&k>slo(x->s,x))sol(k,x->i);
else if(x->t&&slo(x,x->t)>k)sol(k,x->j);
else eq2(f,s*x->x+t*x->y);
}
int main(){
int n;
scanf("%d%lf",&n,&f);
for(int i=1;i<=n;++i){
scanf("%lf%lf%lf",&s,&t,&r);
if(i>1)sol(-s/t);
e[i].x=r*(e[i].y=f/(r*s+t));
upd(e+i);
}
printf("%.3f\n",f);
}

BZOJ1492: [NOI2007]货币兑换Cash的更多相关文章

  1. [BZOJ1492] [NOI2007] 货币兑换Cash(cdq分治+斜率优化)

    [BZOJ1492] [NOI2007] 货币兑换Cash(cdq分治+斜率优化) 题面 分析 dp方程推导 显然,必然存在一种最优的买卖方案满足:每次买进操作使用完所有的人民币:每次卖出操作卖出所有 ...

  2. [BZOJ1492][NOI2007]货币兑换Cash(斜率优化+CDQ分治)

    1492: [NOI2007]货币兑换Cash Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 5838  Solved: 2345[Submit][Sta ...

  3. bzoj1492[NOI2007]货币兑换Cash cdq分治+斜率优化dp

    1492: [NOI2007]货币兑换Cash Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 5541  Solved: 2228[Submit][Sta ...

  4. bzoj千题计划237:bzoj1492: [NOI2007]货币兑换Cash

    http://www.lydsy.com/JudgeOnline/problem.php?id=1492 dp[i] 表示 第i天卖完的最大收益 朴素的dp: 枚举从哪一天买来的在第i天卖掉,或者是不 ...

  5. BZOJ1492: [NOI2007]货币兑换Cash 【dp + CDQ分治】

    1492: [NOI2007]货币兑换Cash Time Limit: 5 Sec  Memory Limit: 64 MB Submit: 5391  Solved: 2181 [Submit][S ...

  6. [BZOJ1492] [NOI2007]货币兑换Cash 斜率优化+cdq/平衡树维护凸包

    1492: [NOI2007]货币兑换Cash Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 5907  Solved: 2377[Submit][Sta ...

  7. Bzoj1492: [NOI2007]货币兑换Cash(不单调的斜率优化)

    题面 传送门 Sol 题目都说了 必然存在一种最优的买卖方案满足: 每次买进操作使用完所有的人民币: 每次卖出操作卖出所有的金券. 设\(f[i]\)表示第\(i\)天可以有的最大钱数 枚举\(j&l ...

  8. bzoj1492 [NOI2007]货币兑换Cash【cdq分治】

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=1492 推荐博客:http://www.cnblogs.com/zig-zag/archive ...

  9. cdq分治入门--BZOJ1492: [NOI2007]货币兑换Cash

    n<=100000天,一开始有s块钱,每天股票A价格ai,B价格bi,每天可以做的事情:卖出股票:按A:B=RTi的比例买入股票.问最后的最大收益.股票可以为浮点数,答案保留三位. 用脚指头想想 ...

随机推荐

  1. shift粘滞键后门创建/复原批处理

    创建shift粘滞键后门: 1 c: 2 3 cd \Windows\System32\ 4 5 rename sethc.exe bak_sethc.exe 6 7 xcopy cmd.exe se ...

  2. 安开发卓之Notification(一)代码直接能用

    Notification是Android中很理想的一种显示提示信息的方法,它可以将应用程序的信息传递到我们的Android桌面状态栏,采用这种消息传递方式不会影响到用户对手机的正常使用.而且Notif ...

  3. 面向初学者之烦人的mainactivity启动前的actionBAR

    相信各位初学者的童鞋都遇到过一个问题,(大神们就别喷我哦,多多帮帮指正,嘿嘿)那就是当你点开你开发的软件或者是dome时,会发现这么一个问题: 你曾今以为你的软件点开的时候是这样的: 然而事实是残酷的 ...

  4. [原创]Linux-day1

    原创:转发务必注明出处http://www.cnblogs.com/0zcl/p/6077298.html 一.Linux的基本原则 由目的单一的小程序组成:组合小程序完成复杂任务 一切皆文件 尽量避 ...

  5. Ubuntu Server 设置PPTP客户端连接

    安装PPTP客户端 apt-get install pptp-linux 设置连接账号信息 sudo vim /etc/ppp/chap-secrets 其中$login_name是登录名:$pass ...

  6. 连载《一个程序猿的生命周期》-《发展篇》 - 3.农民与软件工程师,农业与IT业

    相关文章:随笔<一个程序猿的生命周期>- 逆潮流而动的“叛逆者”        15年前,依稀记得走出大山,进城求学的场景.尽管一路有父亲的陪伴,但是内心仍然畏惧.当父亲转身离去.准备回到 ...

  7. 给Eclipse提速的7个技巧

    这篇文章只是关注如何让Eclipse运行得更快.每个技巧都针对Windows.Linux和MacOS用户详细说明.在使用所有优化技巧之后,Eclipse应该能在10秒内启动,并且比以前运行得更流畅. ...

  8. Favorites of top 10 rules for success

    Dec. 31, 2015 Stayed up to last minute of 2015, 12:00am, watching a few of videos about top 10 rules ...

  9. codevs 1082 线段树练习 3(区间维护)

    codevs 1082 线段树练习 3  时间限制: 3 s  空间限制: 128000 KB  题目等级 : 大师 Master 题目描述 Description 给你N个数,有两种操作: 1:给区 ...

  10. c# (ENUM)枚举组合类型的谷歌序列化Protobuf

    c# (ENUM)枚举组合类型的谷歌序列化Protobuf,必须在序列化/反序列化时加上下面: RuntimeTypeModel.Default[typeof(Alarm)].EnumPassthru ...