P4027 [NOI2007]货币兑换(斜率优化dp+cdq分治)
显然,如果某一天要买券,一定是把钱全部花掉。否则不是最优(攒着干啥)
我们设$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分治)的更多相关文章
- 【bzoj3672】[Noi2014]购票  斜率优化dp+CDQ分治+树的点分治
		
题目描述 给出一棵以1为根的带边权有根树,对于每个根节点以外的点$v$,如果它与其某个祖先$a$的距离$d$不超过$l_v$,则可以花费$p_vd+q_v$的代价从$v$到$a$.问从每个点到1花费 ...
 - LUOGU P4027 [NOI2007]货币兑换 (斜率优化+CDQ分治)
		
传送门 解题思路 题目里有两句提示一定要看清楚,要不全买要不全卖,所以dp方程就比较好列,f[i]=max(f[j]*rate[j]*a[i])/(rate[j]*a[j]+b[j])+(f[j]*b ...
 - BZOJ1492: [NOI2007]货币兑换Cash   【dp + CDQ分治】
		
1492: [NOI2007]货币兑换Cash Time Limit: 5 Sec Memory Limit: 64 MB Submit: 5391 Solved: 2181 [Submit][S ...
 - 【BZOJ2149】拆迁队(斜率优化DP+CDQ分治)
		
题目: 一个斜率优化+CDQ好题 BZOJ2149 分析: 先吐槽一下题意:保留房子反而要给赔偿金是什么鬼哦-- 第一问是一个经典问题.直接求原序列的最长上升子序列是错误的.比如\(\{1,2,2,3 ...
 - HDU 3824/ BZOJ 3963 [WF2011]MachineWorks (斜率优化DP+CDQ分治维护凸包)
		
题面 BZOJ传送门(中文题面但是权限题) HDU传送门(英文题面) 分析 定义f[i]f[i]f[i]表示在iii时间(离散化之后)卖出手上的机器的最大收益.转移方程式比较好写f[i]=max{f[ ...
 - BZOJ 1492 [NOI2007]货币兑换Cash:斜率优化dp + cdq分治
		
传送门 题意 初始时你有 $ s $ 元,接下来有 $ n $ 天. 在第 $ i $ 天,A券的价值为 $ A[i] $ ,B券的价值为 $ B[i] $ . 在第 $ i $ 天,你可以进行两种操 ...
 - [NOI2007]货币兑换 --- DP + 斜率优化(CDQ分治)
		
[NOI2007]货币兑换 题目描述: 小 Y 最近在一家金券交易所工作.该金券交易所只发行交易两种金券:A 纪念券(以下简称 A 券)和 B 纪念券(以下简称 B 券). 每个持有金券的顾客都有一个 ...
 - bzoj 1492: [NOI2007]货币兑换Cash【贪心+斜率优化dp+cdq】
		
参考:http://www.cnblogs.com/lidaxin/p/5240220.html 虽然splay会方便很多,但是懒得写,于是写了cdq 首先要想到贪心的思路,因为如果在某天买入是能得到 ...
 - NOI 2007 货币兑换Cash (bzoj 1492) - 斜率优化 - 动态规划 - CDQ分治
		
Description 小Y最近在一家金券交易所工作.该金券交易所只发行交易两种金券:A纪念券(以下简称A券)和 B纪念券(以下 简称B券).每个持有金券的顾客都有一个自己的帐户.金券的数目可以是一个 ...
 
随机推荐
- linux下vi或vim操作Found a swap file by the name的原因及解决方法
			
在linux下用vi或vim打开Test.java文件时 [root@localhost tmp]# vi Test.java出现了如下信息: E325: ATTENTION Found a s ...
 - Linux块设备IO子系统(一) _驱动模型
			
块设备是Linux三大设备之一,其驱动模型主要针对磁盘,Flash等存储类设备,块设备(blockdevice)是一种具有一定结构的随机存取设备,对这种设备的读写是按块(所以叫块设备)进行的,他使用缓 ...
 - JIRA应用的内存参数设置不当+容器没有对资源进行限制导致服务挂掉的例子
			
背景: 应用的部署结构是这样的:使用rancher管理的Docker集群,有三台物理主机,二十多个Docker容器, 提供的功能是问题跟踪(JIRA),文档管理(Confluence),代码托管(sv ...
 - A - The Water Problem
			
In Land waterless, water is a very limited resource. People always fight for the biggest source of w ...
 - poj3335
			
半平面交&多边形内核.因为没注意了点的情况自闭了. https://blog.csdn.net/qq_40861916/article/details/83541403 这个说的贼好. 多边形 ...
 - node 把文件封装一层文件夹
			
把 pages 下面的单个js文件,封装上一个文件夹 var glob = require("glob"); const fs = require("fs-extra&q ...
 - a标签强制不换行
			
a标签文字强制不换行 强制不换行 a{ white-space:nowrap; } 再补充说明所有关于换行的CSS样式: white-space: normal|pre|nowrap|pre-wrap ...
 - node.js+ react + redux   环境搭建
			
1.安装node.js 2. yarn init: 初始化,主要包含以下条目 name: 项目名 version: 版本号 description: 项目简要描述 entry point: 文件入口, ...
 - Python学习之旅(十八)
			
Python基础知识(17):面向对象编程(Ⅱ) 获取对象信息 在不知道对象信息的情况下,我们想要去获取对象信息,可以使用以下方法 1.type (1)判断对象类型 >>> type ...
 - PAT甲级1135 Is It A Red-Black Tree?【dfs】
			
题目:https://pintia.cn/problem-sets/994805342720868352/problems/994805346063728640 题意: 给定一棵二叉搜索树的先序遍历结 ...