P4027-[NOI2007]货币兑换【斜率优化dp,CDQ分治】

正题

题目链接:https://www.luogu.com.cn/problem/P4027


题目大意

nnn天开始时有SSS元钱,每天AAA种股票价格为aia_iai,BBB种价格为bib_ibi。然后出售必须AAABBB出售相同比例,买入时AAABBB必须按照rir_iri的比例买入。

求最后的钱最多是多少


解题思路

首先考虑dpdpdp

假设有情况是只出售一部分最赚,然后之后(中间不买入)再出售一部分能更赚钱,那么将前面的放在最后出售的那一天出售完显然不会更亏,所以显然不成立,所以每次出售必定是全部出售完。同理,每次买入也是全部买入。

那么我们可以设fif_ifi表示第iii天的最多钱数,那么全部买入时AAA股的数量为xi=firiairi+bix_i=\frac{f_ir_i}{a_ir_i+b_i}xi=airi+bifiriBBB股数量为yi=fiairi+biy_i=\frac{f_i}{a_ir_i+b_i}yi=airi+bifi。有方程式fi=max{fi−1,xjai+yjbi}f_i=max\{f_{i-1},x_ja_i+y_jb_i\}fi=max{fi1,xjai+yjbi}

然后考虑优化方程fi=xjai+yjbif_i=x_ja_i+y_jb_ifi=xjai+yjbi

⇒yj=−aibixj+fibi\Rightarrow y_j=-\frac{a_i}{b_i}x_j+\frac{f_i}{b_i}yj=biaixj+bifi
有一条斜率为−aibi-\frac{a_i}{b_i}biai经过决策点(xj,yj)(x_j,y_j)(xj,yj)

因为bib_ibi固定,所以是要求截距fibi\frac{f_i}{b_i}bifi最大,那么显然每个可能的决策点(xj,yj)(x_j,y_j)(xj,yj)构成一个上凸壳。(斜率递减)

若已经构建了上凸壳,那么如何求答案,首先我们要找到第一个位置使得该决策点的前面的边的斜率大于−aibi-\frac{a_i}{b_i}biai,后面那条边的斜率小于−aibi-\frac{a_i}{b_i}biai即可。

由于都不是单调的,所以我们可以用CDQCDQCDQ分治。

每次计算完[l,mid][l,mid][l,mid]后我们可以用前面的[l,mid][l,mid][l,mid]用单调栈储存凸壳,然后让[mid+1,r][mid+1,r][mid+1,r]保持−aibi-\frac{a_i}{b_i}biai递增,然后即可双指针寻找答案。

时间复杂度O(nlog⁡2n)O(n\log^2 n)O(nlog2n)(如果用归并排序好像可以做到O(nlog⁡n)O(n\log n)O(nlogn)


codecodecode

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
const int N=1e5+10;
int n,p[N],q[N],s[N],tot;
double f[N],x[N],y[N],ra[N],a[N],b[N];
double slope(int a,int b)
{if(fabs(x[a]-x[b])<1e-9)return 1e9;return (y[a]-y[b])/(x[a]-x[b]);
}
bool cmp(int i,int j)
{return a[i]/b[i]>a[j]/b[j];}
bool cMp(int i,int j)
{return x[i]<x[j];}
void cdq(int l,int r){if(l==r){f[l]=max(f[l-1],f[l]);x[l]=f[l]*ra[l]/(a[l]*ra[l]+b[l]);y[l]=f[l]/(a[l]*ra[l]+b[l]);return;}int mid=(l+r)>>1,t1=l,t2=mid+1;for(int i=l;i<=r;i++)if(p[i]<=mid)q[t1++]=p[i];else q[t2++]=p[i];for(int i=l;i<=r;i++)p[i]=q[i];cdq(l,mid);tot=0;for(int i=l;i<=mid;i++){while(tot>1&&slope(s[tot],p[i])>slope(s[tot-1],s[tot]))tot--;s[++tot]=p[i];}for(int i=mid+1;i<=r;i++){while(tot>1&&slope(s[tot-1],s[tot])<-a[p[i]]/b[p[i]])tot--;int pos=s[tot];f[p[i]]=max(f[p[i]],x[pos]*a[p[i]]+y[pos]*b[p[i]]);}cdq(mid+1,r);sort(p+l,p+1+r,cMp);	
}
int main()
{scanf("%d%lf",&n,&f[0]);for(int i=1;i<=n;i++)scanf("%lf%lf%lf",&a[i],&b[i],&ra[i]),p[i]=i;sort(p+1,p+1+n,cmp);cdq(1,n);printf("%.3lf",f[n]);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/321308.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【栈】【字符】匹配(jzoj 1612)

匹配 题目大意&#xff1a; 给你一个长度为n的字符串&#xff08;有多组数据&#xff09;&#xff0c;中间有小写字母&#xff08;没用的东西&#xff09;和大写字母&#xff0c;A-M是左括号&#xff0c;与之相对的是右括号Z-N&#xff08;之所以说是Z-N而不是N-Z是因为只有Z…

codeforces 940E Cashback 有趣的dp

题解 这么明显的一个dp&#xff0c;我怎么就没看出来呢&#xff1f;&#xff01; 首先我们需要一些前提条件&#xff1a;任何划分出来的一个区间的长度不应该超过c。 如果这个区间长度大于c&#xff0c;那么设lenn∗cklenn∗ck&#xff0c;那么这个区间应该被分成n个长度为c的…

理解 C# 项目 csproj 文件格式的本质和编译流程

写了这么多个 C# 项目&#xff0c;是否对项目文件 csproj 有一些了解呢&#xff1f;Visual Studio 是怎么让 csproj 中的内容正确显示出来的呢&#xff1f;更深入的&#xff0c;我能够自己扩展 csproj 的功能吗&#xff1f;本文将直接从 csproj 文件格式的本质来看以上这些问题…

P2000-拯救世界【生成函数,NTT】

正题 题目链接:https://www.luogu.com.cn/problem/P2000 题目大意 十种东西&#xff0c;有要求 金神石A的块数必须是 6 的倍数。 木神石A最多用 9 块。 水神石A最多用 5 块。 火神石A的块数必须是 4 的倍数。 土神石A最多用 7 块。 金神石B的块数必须是 2 的倍数。 木神石B最…

【模拟】生日蛋糕(jzoj 1613)

生日蛋糕 题目大意&#xff1a; 一个正方形蛋糕&#xff0c;竖着横着各切一刀&#xff0c;使他变成四块正方形蛋糕&#xff0c;蛋糕中有一些巧克力&#xff0c;而小明只能拿巧克力最少的一块&#xff0c;请问小明要怎么切才能吃到最多的巧克力 样例输入 8 …#…#… .##……

使用.NET Core与Google Optimization Tools实现加工车间任务规划

前一篇文章《使用.NET Core与Google Optimization Tools实现员工排班计划Scheduling》算是一种针对内容的规划&#xff0c;而针对时间顺序任务规划&#xff0c;加工车间的工活儿是一个典型的场景。在加工车间有不同的工活儿&#xff0c;一般称为作业&#xff0c;每种作业都有多…

P6047-丝之割【斜率优化,dp】

前言 然而丝之鸽还是没有出 正题 题目链接:https://www.luogu.com.cn/problem/P6047 题目大意 两个平行的线&#xff0c;上面连接着若干条弦&#xff0c;第iii条连接上方的xix_ixi​个下方的yiy_iyi​。 然后每次可以选择一个位置(i,j)(i,j)(i,j)&#xff0c;可以切断任何位…

洛谷P1373 小a和uim之大逃离 动态规划

题解 我们可以先简单的想一种状态&#xff0c;也就是dp[i][j][x][y][t]dp[i][j][x][y][t]dp[i][j][x][y][t]&#xff0c;这是最暴力的。 当t0t 0t0时&#xff0c;表示小a处于(i,j)(i,j)(i,j)位置&#xff0c;其中小a拥有x魔液&#xff0c;uim拥有y的魔液时候的方案总数。t1t …

【模拟】游戏(jzoj 1614)

游戏 题目大意&#xff1a; 有一个n*n的棋盘&#xff0c;有一个坐标在x,y的棋子&#xff0c; 1、2号玩家可以将他向左&#xff0c;向下&#xff0c;向左下&#xff08;45∘45^{\circ}45∘&#xff09;移动若干格&#xff0c;假如他们都是AKIOI聪明绝顶的巨佬&#xff0c;请问…

VSTS + XX云服务器构建netcore+docker持续集成交付部署

持续集成交付部署是什么意思,它给我们带来什么好处&#xff1f;先贴一张图持续集成&#xff08;Continuous Integration&#xff09;持续集成强调开发人员提交了新代码之后&#xff0c;立刻进行构建、&#xff08;单元&#xff09;测试(这个要看情况了是否需要)持续交付&#x…

codeforces E. Game with String 概率

题意 这道题目的叙述不好理解&#xff1a; 给你一个字符串ss,小a和小b都知道。现在小b要把字符串的左边一段移动到最右边,生成一个新的字符串s&#x2032;" role="presentation" style="position: relative;">s′s′&#xff0c;小a只知道s′…

P4593-[TJOI2018]教科书般的亵渎【拉格朗日差值】

正题 题目链接:https://www.luogu.com.cn/problem/P4593 题目大意 场上有若干只怪&#xff0c;最高的为nnn&#xff0c;每个怪血量不同&#xff0c;有mmm个血量不存在。 不停释放亵渎&#xff08;全场打一&#xff0c;如果有怪死亡就再次生效&#xff09;&#xff0c;每次一…

【链表】【树形DP】最大利润(jzoj 1487)

最大利润 题目大意&#xff1a; 有n个车站&#xff0c;每个车站有一定的人数&#xff0c;有n-1条线路连接着这些车站&#xff0c;相邻的车站不能同时有两个餐厅&#xff0c;当在一个车站建立餐厅时&#xff0c;会得到这个车站所有人的monny&#xff08;1个人可以得到1份利润&…

P2617-Dynamic Rankings【树套树】

正题 题目链接:https://www.luogu.com.cn/problem/P2617 题目大意 给出一个序列&#xff0c;要求支持 区间查询第kkk大单点修改 解题思路 区间查询第kkk大需要使用主席树&#xff0c;构建权值线段树的前缀和。考虑如何进行单点修改&#xff0c;在前缀和上进行单点修改就是进…

如何创建一个基于 MSBuild Task 的跨平台的 NuGet 工具包

MSBuild 的 Task 为我们扩展项目的编译过程提供了强大的扩展性&#xff0c;它使得我们可以用 C# 语言编写扩展&#xff1b;利用这种扩展性&#xff0c;我们可以为我们的项目定制一部分的编译细节。NuGet 为我们提供了一种自动导入 .props 和 .targets 的方法&#xff0c;同时还…

codeforces F.F. Teodor is not a liar! 最长不降子序列

题意 给出一堆线段。 询问者每次可以询问一个整数点&#xff0c;回答者告诉询问者这个点被多少根线段包括。 问询问者最多问多少次&#xff0c;还不能确定任意一个整数点都不可能被所有的线段包含。 题解 首先用O(n)的方法计算出来每个点被多少条线段包含。 突破点&#x…

2019.01.23【NOIP普及组】模拟赛C组总结

总结 这次的分数是1001000100300 第一题第一题一开始把题看错了&#xff0c;乱打一通&#xff0c;结果才发现自己打错了&#xff0c;把题看清后&#xff0c;就知道用栈&#xff0c;快速解决。第二题和之前做过的一道题十分相似&#xff0c;就是用前缀和来将求一个范围内的巧克…

P2149-[SDOI2009]Elaxia的路线【最短路】

正题 题目链接:https://www.luogu.com.cn/problem/P2149 题目大意 nnn个点mmm条边的一张无向图&#xff0c;给定两个起点和对应的终点。求两个最短路的最长公共距离 解题思路 首先要求是最短路&#xff0c;我们可以先跑一次第一个起点的SPFASPFASPFA&#xff0c;然后从终点开…

Platform.Uno介绍

编者语&#xff1a;Xamarin国内很多人说缺乏可用的实例&#xff0c;我在写书过程中在完善一些常用场景的例子&#xff0c;希望帮到大家。Build 2018结束一周了&#xff0c;善友问我要不要谈谈Xamarin的一些变化&#xff0c;但碍于时间有限一直没有付诸行动。想想总得写点什么给…

codeforces F.Fibonacci String Subsequences

题意 定义F(x)为F(x-1)与F(x-2)的连接&#xff08;其中F(0) ‘0’,F(1) ‘1’&#xff09;。 给出一个长度不超过100的字符串s&#xff0c;询问s在F(x)的所有子序列中出现了多少次。 题解 数量很大的计数问题&#xff0c;我们首先想到的解决方案就是dp。 我们考虑F(x) F…