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. 【HTML5】HTML5中video元素事件详解(实时监测当前播放时间)

    html 代码..video后边几个元素,可处理ios 系统的兼容性 <video id="myVideo" controls="controls" po ...

  2. LeetCode - 768. Max Chunks To Make Sorted II

    This question is the same as "Max Chunks to Make Sorted" except the integers of the given ...

  3. ef报错:实体类型XXX不是当前上下文的模型的一部分。

    可能原因:.net框架版本与实体框架版本不匹配,比如:.net框架版本为4.5.实体框架版本为6.2. 解决方法:将实体框架版本降到6.0.

  4. C# Aspose.Cells导出xlsx格式Excel,打开文件报“Excel 已完成文件级验证和修复。此工作簿的某些部分可能已被修复或丢弃”

    报错信息: 最近打开下载的 Excel,会报如下错误.(xls 格式不受影响) 解决方案: 下载代码(红色为新添代码) public void download() { string fileName ...

  5. socket详解(二)----实例和多线程,线程池使用

    一般而言,Java 语言中的套接字有以下两种形式: TCP 套接字(由 Socket 类实现,) UDP 套接字(由 DatagramSocket 类实现) TCP 和 UDP 扮演相同角色,但做法不 ...

  6. highcharts.js的时间轴折线图

    工作中正好用到. 鼠标按住左键 左右移动可以试试 <!DOCTYPE> <html lang='en'> <head> <title>4-Highcha ...

  7. javascript面试题(2)

    可以参考一  https://www.cnblogs.com/DCL1314/p/7903114.html 1.什么是JavaScript?(这是基本题,对很多程序员来说也是送分题!) JavaScr ...

  8. linux 安装配置nexus以及maven私服应用

    ---------------------nexus---------------------- 1.编辑nexus脚本, 配置 RUN_AS_USER 参数vi /usr/local/src/nex ...

  9. Nestjs 身份验证

    文档 yarn add @nestjs/passport passport passport-http-bearer @nestjs/jwt passport-jwt auth.service.ts ...

  10. socket与http

    参考文档:http://blog.csdn.net/zeng622peng/article/details/5546384 1.TCP连接 手机能够使用联网功能是因为手机底层实现了TCP/IP协议,可 ...