P4027 [NOI2007]货币兑换

显然,如果某一天要买券,一定是把钱全部花掉。否则不是最优(攒着干啥)

我们设$f[j]$为第$j$天时用户手上最多有多少钱

设$w$为花完钱买到的$B$券数

$f[j]=R_{j}*w*A_{j}+w*B_{j}$

$w=f[j]/(R_{j}*A_{j}+B_{j})$

在第$i$天的转移方程:

$f[i]=R_{j}*w*A_{i}+w*B_{i}$

$w*B_{i}=-R_{j}*w*A_{i}+f[i]$

$w=-A_{i}/B_{i}*R_{j}*w+f[i]/B_{i}$

又化成了熟悉的$y=k*x+b$

$y=w$

$k=-A_{i}/B_{i}$

$x=R_{j}*w$

$b=f[i]/B_{i}$

于是就变成了熟悉的斜率优化辣

可是本题中的$k,x$均不单调

不能直接上单调队列维护凸包

于是我们使用cdq分治让$x$单调

再把$k$排序

在分治过程中维护凸包

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#define rint register int
using namespace std;
typedef double db;
#define N 100005
inline db Max(db a,db b){return a>b?a:b;}
int n,tp,h[N]; db f[N];
struct data{db k,X,Y,A,B,R;int id;}a[N],b[N];
inline bool cmp(data x,data y){return x.k<y.k;}
//inline db K(int x,int y){return (a[x].Y-a[y].Y)/(a[x].X-a[y].X);}
inline db KK(db x1,db x2,db y1,db y2){return x1*y2-x2*y1;}//斜率比较时避免除法,减少误差
void CDQ(int l,int r){
if(l==r){//l之前的询问已处理完
f[l]=Max(f[l],f[l-]);
a[l].Y=f[l]/(a[l].A*a[l].R+a[l].B);
a[l].X=a[l].Y*a[l].R;
return ;
}int mid=(l+r)>>; tp=;//可以取(0,0)(大雾)
for(rint i=l,L=l,R=mid+;i<=r;++i){
if(a[i].id<=mid) b[L++]=a[i];
else b[R++]=a[i];
}//前mid个询问扔到左边,后mid个扔到右边
for(rint i=l;i<=r;++i) a[i]=b[i];
CDQ(l,mid);
for(rint i=l;i<=mid;++i){
//while(tp&&K(h[tp],i)>K(h[tp-1],h[tp])) --tp;
while(tp&&KK(a[i].X-a[h[tp]].X,a[i].Y-a[h[tp]].Y,
a[h[tp]].X-a[h[tp-]].X,a[h[tp]].Y-a[h[tp-]].Y)<=) --tp; h[++tp]=i;
}//凸包维护
for(rint i=mid+;i<=r;++i){//处理右边的询问
//while(tp&&K(h[tp-1],h[tp])<=a[i].k) --tp;
while(tp&&KK(,a[i].k,a[h[tp]].X-a[h[tp-]].X,
a[h[tp]].Y-a[h[tp-]].Y)<=) --tp; f[a[i].id]=Max(f[a[i].id],a[h[tp]].X*a[i].A+a[h[tp]].Y*a[i].B);//
}CDQ(mid+,r);
for(rint i=l,L=l,R=mid+;i<=r;++i)//按X坐标排序
b[i]=(L<=mid&&(R>r||a[L].X<a[R].X))?a[L++]:a[R++];
for(rint i=l;i<=r;++i) a[i]=b[i];
}
int main(){
//freopen("P4027.in","r",stdin);
scanf("%d%lf",&n,&f[]);
for(rint i=;i<=n;++i){
scanf("%lf%lf%lf",&a[i].A,&a[i].B,&a[i].R);
a[i].k=-a[i].A/a[i].B; a[i].id=i;
}sort(a+,a+n+,cmp);
CDQ(,n); printf("%.3lf",f[n]);
return ;
}

P4027 [NOI2007]货币兑换(斜率优化dp+cdq分治)的更多相关文章

  1. 【bzoj3672】[Noi2014]购票 斜率优化dp+CDQ分治+树的点分治

    题目描述  给出一棵以1为根的带边权有根树,对于每个根节点以外的点$v$,如果它与其某个祖先$a$的距离$d$不超过$l_v$,则可以花费$p_vd+q_v$的代价从$v$到$a$.问从每个点到1花费 ...

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

    传送门 解题思路 题目里有两句提示一定要看清楚,要不全买要不全卖,所以dp方程就比较好列,f[i]=max(f[j]*rate[j]*a[i])/(rate[j]*a[j]+b[j])+(f[j]*b ...

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

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

  4. 【BZOJ2149】拆迁队(斜率优化DP+CDQ分治)

    题目: 一个斜率优化+CDQ好题 BZOJ2149 分析: 先吐槽一下题意:保留房子反而要给赔偿金是什么鬼哦-- 第一问是一个经典问题.直接求原序列的最长上升子序列是错误的.比如\(\{1,2,2,3 ...

  5. HDU 3824/ BZOJ 3963 [WF2011]MachineWorks (斜率优化DP+CDQ分治维护凸包)

    题面 BZOJ传送门(中文题面但是权限题) HDU传送门(英文题面) 分析 定义f[i]f[i]f[i]表示在iii时间(离散化之后)卖出手上的机器的最大收益.转移方程式比较好写f[i]=max{f[ ...

  6. BZOJ 1492 [NOI2007]货币兑换Cash:斜率优化dp + cdq分治

    传送门 题意 初始时你有 $ s $ 元,接下来有 $ n $ 天. 在第 $ i $ 天,A券的价值为 $ A[i] $ ,B券的价值为 $ B[i] $ . 在第 $ i $ 天,你可以进行两种操 ...

  7. [NOI2007]货币兑换 --- DP + 斜率优化(CDQ分治)

    [NOI2007]货币兑换 题目描述: 小 Y 最近在一家金券交易所工作.该金券交易所只发行交易两种金券:A 纪念券(以下简称 A 券)和 B 纪念券(以下简称 B 券). 每个持有金券的顾客都有一个 ...

  8. bzoj 1492: [NOI2007]货币兑换Cash【贪心+斜率优化dp+cdq】

    参考:http://www.cnblogs.com/lidaxin/p/5240220.html 虽然splay会方便很多,但是懒得写,于是写了cdq 首先要想到贪心的思路,因为如果在某天买入是能得到 ...

  9. NOI 2007 货币兑换Cash (bzoj 1492) - 斜率优化 - 动态规划 - CDQ分治

    Description 小Y最近在一家金券交易所工作.该金券交易所只发行交易两种金券:A纪念券(以下简称A券)和 B纪念券(以下 简称B券).每个持有金券的顾客都有一个自己的帐户.金券的数目可以是一个 ...

随机推荐

  1. 【奇淫技巧】API接口字段table文档转代码工具

    今天做一个视频接口对接,发现对方提供的文档没有json格式,无法自动生成请求和响应对象 json自动生成C#类的工具 http://tool.sufeinet.com/Creater/JsonClas ...

  2. 关于Redis 应用 的一些 感悟

    最近在项目中 使用了 Redis技术

  3. JBPM工作流(五)——执行流程实例

    概念: ProcessInstance,流程实例:代表流程定义的一次执行.如:张三昨天按请假流程请了一次假.一个流程实例包括了所有运行阶段,其中最典型的属性就是跟踪当前节点的指针,如下图. Execu ...

  4. hibernate04--三种状态之间的转换

    public class StudentTest { Session session=null; Transaction transaction=null; //在执行测试方法之前 先执行before ...

  5. 原生 JavaScript 实现 state 状态管理系统

    原生 JavaScript 实现 state 状态管理系统 Build a state management system with vanilla JavaScript | CSS-Tricks 在 ...

  6. 19、AJAX

    1.Ajax的概念 Ajax是一种在无需重新加载整个网页(刷新页面)的情况下,能够更新部分网页的技术. Ajax的全称是AsynchronousJavaScript and XML,即异步JavaSc ...

  7. sqoop/1.4.6/下载

    http://archive.apache.org/dist/sqoop/1.4.6/

  8. H5选择颜色-前端颜色选择器

    开发一年多了,一直用angular2框架,框架虽然能大大减少程序员的工作量,但我还是更喜欢用原生的技术写代码. 原生的就像内功心法,框架是招式,招式虽然实用,但是想成为高手还是得有内功修养. 不多说, ...

  9. JavaScript 世界万物诞生记

    一. 无中生有 起初,什么都没有.造物主说:没有东西本身也是一种东西啊,于是就有了null: 现在我们要造点儿东西出来.但是没有原料怎么办?有一个声音说:不是有null嘛?另一个声音说:可是null代 ...

  10. A - Shashlik Cooking CodeForces - 1040B

    http://codeforces.com/problemset/problem/1040/B Long story short, shashlik is Miroslav's favorite fo ...