1492: [NOI2007]货币兑换Cash【CDQ分治】
1492: [NOI2007]货币兑换Cash
Time Limit: 5 Sec Memory Limit: 64 MB
Submit: 4166 Solved: 1736
[Submit][Status][Discuss]
Description
.png)
.png)
Input
Output
只有一个实数MaxProfit,表示第N天的操作结束时能够获得的最大的金钱数目。答案保留3位小数。
Sample Input
1 1 1
1 2 2
2 2 3
Sample Output
HINT
Source
分析:
引用:《从<Cash>谈一类分治算法的应用》
- //原论文CDQ:O(n*logn)
- //本代码:O(n*logn*logn)
- #pragma GCC optimize("O2")
- #include<cstdio>
- #include<cstring>
- #include<iostream>
- #include<algorithm>
- using namespace std;
- const int N=1e5+;
- const int inf=0x3fffffff;
- const double eps=1e-;
- double A[N],B[N],R[N],f[N],dp[N];
- struct Point{
- double x,y;
- Point(double x=0.0,double y=0.0):x(x),y(y) {}
- };
- typedef Point Vector;
- Vector operator + (Vector A,Vector B){
- return Vector(A.x+B.x,A.y+B.y);
- }
- Vector operator - (Point A,Point B){
- return Vector(A.x-B.x,A.y-B.y);
- }
- Vector operator * (Vector A,double p){
- return Vector(A.x*p,A.y*p);
- }
- Vector operator / (Vector A,double p){
- return Vector(A.x/p,A.y/p);
- }
- bool operator < (const Point &a,const Point &b){
- return a.x<b.x||(a.x==b.x&&a.y<b.y);
- }
- double Dot(Vector A,Vector B){
- return A.x*B.x+A.y*B.y;
- }
- double Cross(Vector A,Vector B){
- return A.x*B.y-A.y*B.x;
- }
- double x(int i){
- return dp[i]*R[i]/f[i];
- }
- double y(int i){
- return dp[i]/f[i];
- }
- bool cmp(int i,int j){
- return A[i]*B[j]>A[j]*B[i];
- }
- int ConvexHull(Point *p,int n,Point *Poly){
- sort(p,p+n);
- int m=;
- for(int i=n-;i>=;i--){
- while(m> && Cross(Poly[m-]-Poly[m-],p[i]-Poly[m-]) <= ) m--;
- Poly[m++]=p[i];
- }
- return m;
- }
- Point P[N],Poly[N];
- int tmp[N];
- void cdq(int l,int r){
- if(l==r){
- dp[l]=max(dp[l],dp[l-]);
- return ;
- }
- int mid=l+r>>;
- cdq(l,mid);
- int cnt=;
- for(int i=l;i<=mid;i++)
- P[cnt++]=Point(x(i),y(i));
- cnt=ConvexHull(P,cnt,Poly);
- for(int i=mid+;i<=r;i++)
- tmp[i]=i;
- sort(tmp+mid+,tmp+r+,cmp);
- int i=,j=mid+;
- while(j<=r){
- while(i<cnt-&&(Poly[i].y-Poly[i+].y)*B[tmp[j]]<-1.0*(Poly[i].x-Poly[i+].x)*A[tmp[j]]){
- i++;
- }
- dp[tmp[j]]=max(dp[tmp[j]],A[tmp[j]]*Poly[i].x+B[tmp[j]]*Poly[i].y);
- j++;
- }
- cdq(mid+,r);
- }
- int main(){
- int n,s;
- cin>>n>>s;
- for(int i=;i<=n;i++){
- scanf("%lf %lf %lf",&A[i],&B[i],&R[i]);
- f[i]=A[i]*R[i]+B[i];
- }
- memset(dp,,sizeof dp);
- dp[]=1.0*s;
- cdq(,n);
- double ans=;
- for(int i=;i<=n;i++)
- ans=max(ans,dp[i]);
- printf("%.3lf\n",ans);
- return ;
- }
1492: [NOI2007]货币兑换Cash【CDQ分治】的更多相关文章
- BZOJ 1492: [NOI2007]货币兑换Cash [CDQ分治 斜率优化DP]
传送门 题意:不想写... 扔链接就跑 好吧我回来了 首先发现每次兑换一定是全部兑换,因为你兑换说明有利可图,是为了后面的某一天两种卷的汇率差别明显而兑换 那么一定拿全利啊,一定比多天的组合好 $f[ ...
- BZOJ 1492 [NOI2007]货币兑换Cash (CDQ分治/splay 维护凸包)
题目大意:太长了略 splay调了两天一直WA弃疗了 首先,我们可以猜一个贪心,如果买/卖,就一定都买/卖掉,否则不买/卖 反正货币的行情都是已知的,没有任何风险,所以肯定要选择最最最优的方案了 容易 ...
- [BZOJ1492] [NOI2007] 货币兑换Cash(cdq分治+斜率优化)
[BZOJ1492] [NOI2007] 货币兑换Cash(cdq分治+斜率优化) 题面 分析 dp方程推导 显然,必然存在一种最优的买卖方案满足:每次买进操作使用完所有的人民币:每次卖出操作卖出所有 ...
- bzoj1492[NOI2007]货币兑换Cash cdq分治+斜率优化dp
1492: [NOI2007]货币兑换Cash Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 5541 Solved: 2228[Submit][Sta ...
- BZOJ1492: [NOI2007]货币兑换Cash(CDQ分治,斜率优化动态规划)
Description 小Y最近在一家金券交易所工作.该金券交易所只发行交易两种金券:A纪念券(以下简称A券)和 B纪念券(以下 简称B券).每个持有金券的顾客都有一个自己的帐户.金券的数目可以是一个 ...
- 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的数量. 然后就很明显了...平衡 ...
- 【BZOJ】1492: [NOI2007]货币兑换Cash(cdq分治)
http://www.lydsy.com/JudgeOnline/problem.php?id=1492 蒟蒻来学学cdq神算法啊.. 详见论文 陈丹琦<从<Cash>谈一类分治算法 ...
- bzoj 1492 [NOI2007]货币兑换Cash(斜率dp+cdq分治)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1492 [题意] 有AB两种货币,每天可以可以付IPi元,买到A券和B券,且A:B= ...
- BZOJ 1492 货币兑换 Cash CDQ分治
这题n2算法就是一个维护上凸包的过程. 也可以用CDQ分治做. 我的CDQ分治做法和网上的不太一样,用左边的点建立一个凸包,右边的点在上面二分. 好处是思路清晰,避免了凸包的插入删除,坏处是多了一个l ...
随机推荐
- hdu 1558 线段相交+并查集路径压缩
Segment set Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- poj 1081 To The Max
To The Max Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total ...
- DataSet用法一:添加代码创建的表DataTable,设置主键外键,读取及修改DataSet表中数据
原文发布时间为:2008-08-01 -- 来源于本人的百度文章 [由搬家工具导入] using System;using System.Data;using System.Configuration ...
- AC日记——Pupils Redistribution Codeforces 779a
A. Pupils Redistribution time limit per test 1 second memory limit per test 256 megabytes input stan ...
- liteos事件(六)
1. 概述 1.1 基本概念 事件是一种实现任务间通信的机制,可用于实现任务间的同步,但事件通信只能是事件类型的通信,无数据传输.一个任务可以等待多个事件的发生:可以是任意一个事件发生时唤醒任务进行事 ...
- cf744
Codeforces Round #385 (Div. 1) <br > A.Hongcow Builds A Nation 贪心. 显然就是凑成一个最大的块即可 那么首先并查集处理已经确 ...
- javascript 函数初探 (三)--- javascript 变量的作用域
javascript 变量的作用域: 这是一个至关重要的问题.特别是当我们从别的语言转向javascript时,必须要明白一点,即在javascript中,变量的定义并不是以代码块作为作用域的,而是以 ...
- 邁向IT專家成功之路的三十則鐵律 鐵律十一:IT人應對之道-靈活
身為一位優秀的IT專家,不能夠只是在技術面的應對能力強,而必須是在人事的應對能力上也要能夠靈活與彈性,否則就算一天給你48小時,你也會把自己的身心弄垮,再強的專業.技術.能力也會瞬間化為泡影. 坦白說 ...
- Android Design Support Library概览
尊重劳动成果.转载请注明出处:http://blog.csdn.net/growth58/article/details/47972467 关注新浪微博:@于卫国 邮箱:yuweiguocn@gmai ...
- JS推断浏览器类型与版本号
在JS中推断浏览器的类型,预计是每一个编辑过页面的开发者都遇到过的问题.在众多的浏览器产品中.IE.Firefox.Opera.Safari........众多品牌却标准不一,因此时常须要依据不同的浏 ...