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. zhenya moves from parents

    Zhenya moved from his parents' home to study in other city. He didn't take any cash with him, he onl ...

  2. JBPM工作流(一)——实现一个简单的工作流例子

    一.JBPM定义 JBPM,全称是Java Business Process Management(业务流程管理),它是覆盖了业务流程管理.工作流.服务协作等领域的一个开源的.灵活的.易扩展的可执行流 ...

  3. 五子棋棋盘布局 table和ul哪个好

    想要在页面布局以上棋盘,可以用ul li 布局,但却有明显的缺点: 1.两行两列:ul li 下面如果再放li 会出错,只能是放其他的,比如div. 或者放li *行*列: 但是这样有两个明显缺陷: ...

  4. MongoDB数据导出

    在bin目录下(没有设置环境变量), mongoexport -d Structure_Patents_infos -c patents_texts -o D:\Postgraduate\Python ...

  5. c++课设

    #include <stdio.h>#include <time.h>#include <math.h>#define C 60000;struct Student ...

  6. smartFloat

    $.fn.smartFloat = function() {     var position = function(element) {         var top = element.posi ...

  7. vim创建程序文件自动添加头部注释/自动文件头注释与模板定义

    Vim 自动文件头注释与模板定义 在vim的配置文件.vimrc添加一些配置可以实现创建新文件时自动添加文件头注释,输入特定命令可以生成模板. 使用方法 插入模式输入模式输入seqlogic[Ente ...

  8. ADG日志传输方式参数log_archive_dest_n详解

    主库的日志发送是由log_archive_dest_n参数设置(注意:同时还有一个和它相对应的开关参数log_archive_dest_state_n,用于指定该参数是否有效),下面简单介绍下该参数各 ...

  9. 《PHP - CGI/Fastcgi/PHP-FPM》

    先说下我最近看到的一篇文章,哈哈哈,特别好玩. 一步步教你编写不可维护的 PHP 代码 之前一直知道 PHP 在 CGI 模式下运行.命令行下在 CLI 模式下运行. 但是 FPM 和 nginx 配 ...

  10. luogu3830 [SHOI2012]随机树

    传送门:洛谷 题目大意:对于一个只有一个节点的二叉树,一次操作随机将这棵树的叶节点的下方增加两个节点.$n-1$次操作后变为$n$个叶节点的二叉树.求:(1)叶节点平均深度的期望值(2)树深度的数学期 ...