1492: [NOI2007]货币兑换Cash

Time Limit: 5 Sec  Memory Limit: 64 MB
Submit: 4166  Solved: 1736
[Submit][Status][Discuss]

Description

小Y最近在一家金券交易所工作。该金券交易所只发行交易两种金券:A纪念券(以下简称A券)和 B纪念券(以下
简称B券)。每个持有金券的顾客都有一个自己的帐户。金券的数目可以是一个实数。每天随着市场的起伏波动,
两种金券都有自己当时的价值,即每一单位金券当天可以兑换的人民币数目。我们记录第 K 天中 A券 和 B券 的
价值分别为 AK 和 BK(元/单位金券)。为了方便顾客,金券交易所提供了一种非常方便的交易方式:比例交易法
。比例交易法分为两个方面:(a)卖出金券:顾客提供一个 [0,100] 内的实数 OP 作为卖出比例,其意义为:将
 OP% 的 A券和 OP% 的 B券 以当时的价值兑换为人民币;(b)买入金券:顾客支付 IP 元人民币,交易所将会兑
换给用户总价值为 IP 的金券,并且,满足提供给顾客的A券和B券的比例在第 K 天恰好为 RateK;例如,假定接
下来 3 天内的 Ak、Bk、RateK 的变化分别为:
假定在第一天时,用户手中有 100元 人民币但是没有任何金券。用户可以执行以下的操作:
注意到,同一天内可以进行多次操作。小Y是一个很有经济头脑的员工,通过较长时间的运作和行情测算,他已经
知道了未来N天内的A券和B券的价值以及Rate。他还希望能够计算出来,如果开始时拥有S元钱,那么N天后最多能
够获得多少元钱。

Input

输入第一行两个正整数N、S,分别表示小Y能预知的天数以及初始时拥有的钱数。接下来N行,第K行三个实数AK、B
K、RateK,意义如题目中所述。对于100%的测试数据,满足:0<AK≤10;0<BK≤10;0<RateK≤100;MaxProfit≤1
0^9。
【提示】
1.输入文件可能很大,请采用快速的读入方式。
2.必然存在一种最优的买卖方案满足:
每次买进操作使用完所有的人民币;
每次卖出操作卖出所有的金券。
 

Output

只有一个实数MaxProfit,表示第N天的操作结束时能够获得的最大的金钱数目。答案保留3位小数。

Sample Input

3 100
1 1 1
1 2 2
2 2 3

Sample Output

225.000

HINT

Source

分析:

引用:《从<Cash>谈一类分治算法的应用》

  1. //原论文CDQ:O(n*logn)
  2. //本代码:O(n*logn*logn)
  3. #pragma GCC optimize("O2")
  4. #include<cstdio>
  5. #include<cstring>
  6. #include<iostream>
  7. #include<algorithm>
  8. using namespace std;
  9. const int N=1e5+;
  10. const int inf=0x3fffffff;
  11. const double eps=1e-;
  12. double A[N],B[N],R[N],f[N],dp[N];
  13. struct Point{
  14. double x,y;
  15. Point(double x=0.0,double y=0.0):x(x),y(y) {}
  16. };
  17. typedef Point Vector;
  18. Vector operator + (Vector A,Vector B){
  19. return Vector(A.x+B.x,A.y+B.y);
  20. }
  21. Vector operator - (Point A,Point B){
  22. return Vector(A.x-B.x,A.y-B.y);
  23. }
  24. Vector operator * (Vector A,double p){
  25. return Vector(A.x*p,A.y*p);
  26. }
  27. Vector operator / (Vector A,double p){
  28. return Vector(A.x/p,A.y/p);
  29. }
  30. bool operator < (const Point &a,const Point &b){
  31. return a.x<b.x||(a.x==b.x&&a.y<b.y);
  32. }
  33. double Dot(Vector A,Vector B){
  34. return A.x*B.x+A.y*B.y;
  35. }
  36. double Cross(Vector A,Vector B){
  37. return A.x*B.y-A.y*B.x;
  38. }
  39. double x(int i){
  40. return dp[i]*R[i]/f[i];
  41. }
  42. double y(int i){
  43. return dp[i]/f[i];
  44. }
  45. bool cmp(int i,int j){
  46. return A[i]*B[j]>A[j]*B[i];
  47. }
  48. int ConvexHull(Point *p,int n,Point *Poly){
  49. sort(p,p+n);
  50. int m=;
  51. for(int i=n-;i>=;i--){
  52. while(m> && Cross(Poly[m-]-Poly[m-],p[i]-Poly[m-]) <= ) m--;
  53. Poly[m++]=p[i];
  54. }
  55. return m;
  56. }
  57. Point P[N],Poly[N];
  58. int tmp[N];
  59. void cdq(int l,int r){
  60. if(l==r){
  61. dp[l]=max(dp[l],dp[l-]);
  62. return ;
  63. }
  64. int mid=l+r>>;
  65. cdq(l,mid);
  66. int cnt=;
  67. for(int i=l;i<=mid;i++)
  68. P[cnt++]=Point(x(i),y(i));
  69. cnt=ConvexHull(P,cnt,Poly);
  70. for(int i=mid+;i<=r;i++)
  71. tmp[i]=i;
  72. sort(tmp+mid+,tmp+r+,cmp);
  73. int i=,j=mid+;
  74. while(j<=r){
  75. while(i<cnt-&&(Poly[i].y-Poly[i+].y)*B[tmp[j]]<-1.0*(Poly[i].x-Poly[i+].x)*A[tmp[j]]){
  76. i++;
  77. }
  78. dp[tmp[j]]=max(dp[tmp[j]],A[tmp[j]]*Poly[i].x+B[tmp[j]]*Poly[i].y);
  79. j++;
  80. }
  81. cdq(mid+,r);
  82. }
  83. int main(){
  84. int n,s;
  85. cin>>n>>s;
  86. for(int i=;i<=n;i++){
  87. scanf("%lf %lf %lf",&A[i],&B[i],&R[i]);
  88. f[i]=A[i]*R[i]+B[i];
  89. }
  90. memset(dp,,sizeof dp);
  91. dp[]=1.0*s;
  92. cdq(,n);
  93. double ans=;
  94. for(int i=;i<=n;i++)
  95. ans=max(ans,dp[i]);
  96. printf("%.3lf\n",ans);
  97. return ;
  98. }

1492: [NOI2007]货币兑换Cash【CDQ分治】的更多相关文章

  1. BZOJ 1492: [NOI2007]货币兑换Cash [CDQ分治 斜率优化DP]

    传送门 题意:不想写... 扔链接就跑 好吧我回来了 首先发现每次兑换一定是全部兑换,因为你兑换说明有利可图,是为了后面的某一天两种卷的汇率差别明显而兑换 那么一定拿全利啊,一定比多天的组合好 $f[ ...

  2. BZOJ 1492 [NOI2007]货币兑换Cash (CDQ分治/splay 维护凸包)

    题目大意:太长了略 splay调了两天一直WA弃疗了 首先,我们可以猜一个贪心,如果买/卖,就一定都买/卖掉,否则不买/卖 反正货币的行情都是已知的,没有任何风险,所以肯定要选择最最最优的方案了 容易 ...

  3. [BZOJ1492] [NOI2007] 货币兑换Cash(cdq分治+斜率优化)

    [BZOJ1492] [NOI2007] 货币兑换Cash(cdq分治+斜率优化) 题面 分析 dp方程推导 显然,必然存在一种最优的买卖方案满足:每次买进操作使用完所有的人民币:每次卖出操作卖出所有 ...

  4. bzoj1492[NOI2007]货币兑换Cash cdq分治+斜率优化dp

    1492: [NOI2007]货币兑换Cash Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 5541  Solved: 2228[Submit][Sta ...

  5. BZOJ1492: [NOI2007]货币兑换Cash(CDQ分治,斜率优化动态规划)

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

  6. BZOJ 1492: [NOI2007]货币兑换Cash( dp + 平衡树 )

    dp(i) = max(dp(i-1), x[j]*a[i]+y[j]*b[i]), 0<j<i. x, y表示某天拥有的最多钱去买金券, 金券a和金券b的数量. 然后就很明显了...平衡 ...

  7. 【BZOJ】1492: [NOI2007]货币兑换Cash(cdq分治)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1492 蒟蒻来学学cdq神算法啊.. 详见论文 陈丹琦<从<Cash>谈一类分治算法 ...

  8. bzoj 1492 [NOI2007]货币兑换Cash(斜率dp+cdq分治)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1492   [题意] 有AB两种货币,每天可以可以付IPi元,买到A券和B券,且A:B= ...

  9. BZOJ 1492 货币兑换 Cash CDQ分治

    这题n2算法就是一个维护上凸包的过程. 也可以用CDQ分治做. 我的CDQ分治做法和网上的不太一样,用左边的点建立一个凸包,右边的点在上面二分. 好处是思路清晰,避免了凸包的插入删除,坏处是多了一个l ...

随机推荐

  1. hdu 1558 线段相交+并查集路径压缩

    Segment set Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  2. poj 1081 To The Max

    To The Max Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total ...

  3. DataSet用法一:添加代码创建的表DataTable,设置主键外键,读取及修改DataSet表中数据

    原文发布时间为:2008-08-01 -- 来源于本人的百度文章 [由搬家工具导入] using System;using System.Data;using System.Configuration ...

  4. AC日记——Pupils Redistribution Codeforces 779a

    A. Pupils Redistribution time limit per test 1 second memory limit per test 256 megabytes input stan ...

  5. liteos事件(六)

    1. 概述 1.1 基本概念 事件是一种实现任务间通信的机制,可用于实现任务间的同步,但事件通信只能是事件类型的通信,无数据传输.一个任务可以等待多个事件的发生:可以是任意一个事件发生时唤醒任务进行事 ...

  6. cf744

    Codeforces Round #385 (Div. 1) <br > A.Hongcow Builds A Nation 贪心. 显然就是凑成一个最大的块即可 那么首先并查集处理已经确 ...

  7. javascript 函数初探 (三)--- javascript 变量的作用域

    javascript 变量的作用域: 这是一个至关重要的问题.特别是当我们从别的语言转向javascript时,必须要明白一点,即在javascript中,变量的定义并不是以代码块作为作用域的,而是以 ...

  8. 邁向IT專家成功之路的三十則鐵律 鐵律十一:IT人應對之道-靈活

    身為一位優秀的IT專家,不能夠只是在技術面的應對能力強,而必須是在人事的應對能力上也要能夠靈活與彈性,否則就算一天給你48小時,你也會把自己的身心弄垮,再強的專業.技術.能力也會瞬間化為泡影. 坦白說 ...

  9. Android Design Support Library概览

    尊重劳动成果.转载请注明出处:http://blog.csdn.net/growth58/article/details/47972467 关注新浪微博:@于卫国 邮箱:yuweiguocn@gmai ...

  10. JS推断浏览器类型与版本号

    在JS中推断浏览器的类型,预计是每一个编辑过页面的开发者都遇到过的问题.在众多的浏览器产品中.IE.Firefox.Opera.Safari........众多品牌却标准不一,因此时常须要依据不同的浏 ...