斜率优化(CDQ分治,Splay平衡树):BZOJ 1492: [NOI2007]货币兑换Cash

Description

Input

第一行两个正整数N、S,分别表示小Y 能预知的天数以及初始时拥有的钱数。 接下来N 行,第K 行三个实数AK、BK、RateK,意义如题目中所述

Output

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

Sample Input

3 100
1 1 1
1 2 2
2 2 3

Sample Output

225.000

HINT



测试数据设计使得精度误差不会超过10-7。
对于40%的测试数据,满足N ≤ 10;
对于60%的测试数据,满足N ≤ 1 000;
对于100%的测试数据,满足N ≤ 100 000;

 1 #include <iostream>
 2 #include <cstring>
 3 #include <cstdio>
 4 #include <algorithm>
 5 using namespace std;
 6 const double eps=1e-8;
 7 const int maxn=100010;
 8 struct Node{
 9     double a,b,r,x,y,k;
10     int id;
11 }d[maxn],t[maxn];
12 double f[maxn];
13 int st[maxn],cnt,n;
14 double Abs(double a){return a>0?a:-a;}
15 double K(int a,int b){
16     if(Abs(d[a].x-d[b].x)<eps)return 1e20;
17     return (d[a].y-d[b].y)/(d[a].x-d[b].x);
18 }
19 void Solve(int l,int r){
20     if(l==r){
21         f[l]=max(f[l],f[l-1]);
22         d[l].y=f[l]/(d[l].r*d[l].a+d[l].b);
23         d[l].x=d[l].y*d[l].r;
24         return;
25     }
26     int mid=(l+r)>>1,t1=l,t2=mid+1;
27     for(int i=l;i<=r;i++){
28         if(d[i].id<=mid)
29             t[t1++]=d[i];
30         else 
31             t[t2++]=d[i];
32     }
33     for(int i=l;i<=r;i++)d[i]=t[i];
34     Solve(l,mid);
35     cnt=0;
36     for(int i=l;i<=mid;i++){
37         while(cnt>1&&K(i,st[cnt])-K(st[cnt],st[cnt-1])>=eps)cnt--;
38         st[++cnt]=i;
39     }
40     int fir=1;
41     for(int i=mid+1;i<=r;i++){
42         while(fir<cnt&&K(st[fir+1],st[fir])-d[i].k>=eps)fir++;
43         f[d[i].id]=max(f[d[i].id],d[st[fir]].x*d[i].a+d[st[fir]].y*d[i].b);
44     }
45     Solve(mid+1,r);
46     t1=l;t2=mid+1;
47     for(int i=l;i<=r;i++){
48         if(t2==r+1||(d[t2].x-d[t1].x>=eps||Abs(d[t2].x-d[t1].x)<eps&&d[t2].y-d[t1].y>=eps)&&t1<=mid)
49             t[i]=d[t1++];
50         else    
51             t[i]=d[t2++];
52     }    
53     for(int i=l;i<=r;i++)
54         d[i]=t[i];
55 }
56 
57 
58 bool cmp(Node a,Node b){
59     return a.k>b.k;
60 }
61 int main(){
62     scanf("%d%lf",&n,&f[1]);
63     for(int i=1;i<=n;i++){
64         scanf("%lf%lf%lf",&d[i].a,&d[i].b,&d[i].r);
65         d[i].k=-d[i].a/d[i].b;
66         d[i].id=i;
67     }
68     sort(d+1,d+n+1,cmp);
69     Solve(1,n);
70     printf("%.3lf\n",f[n]);
71     return 0;
72 }

  这里还有Splay。

  1 #include <iostream>
  2 #include <cstring>
  3 #include <cstdio>
  4 using namespace std;
  5 const double eps=1e-8;
  6 const double INF=1e20;
  7 const int maxn=100010;
  8 int ch[maxn][2],fa[maxn],rt,tot,n;
  9 double X[maxn],Y[maxn],lk[maxn],rk[maxn],ans;
 10 double fabs(double x){return (x>0)?x:-x;}
 11 void Rotate(int x){
 12     int y=fa[x],g=fa[y],c=ch[y][1]==x;
 13     ch[y][c]=ch[x][c^1];fa[ch[y][c]]=y;
 14     ch[x][c^1]=y;fa[y]=x;fa[x]=g;
 15     if(g)ch[g][ch[g][1]==y]=x;
 16 }
 17 
 18 void Splay(int x,int g=0){
 19     for(int y;(y=fa[x])!=g;Rotate(x))
 20         if(fa[y]!=g)Rotate((ch[fa[y]][1]==y)==(ch[y][1]==x)?y:x);
 21     if(!g)rt=x;    
 22 }
 23 
 24 double Get_K(int j,int k){
 25     if(fabs(X[j]-X[k])<=eps)return INF;
 26     else return (Y[j]-Y[k])/(X[j]-X[k]);
 27 }
 28 
 29 int Get_Prev(){
 30     int p=ch[rt][0],ret=p;
 31     while(p){
 32         if(Get_K(rt,p)+eps>=lk[p])p=ch[p][0];
 33         else ret=p,p=ch[p][1];
 34     }
 35     return ret;
 36 }
 37 
 38 int Get_Succ(){
 39     int p=ch[rt][1],ret=p;
 40     while(p){
 41         if(Get_K(p,rt)<=rk[p]+eps)p=ch[p][1];
 42         else ret=p,p=ch[p][0];
 43     }
 44     return ret;
 45 }
 46 
 47 void Insert(int &r,int pre,int p){
 48     if(r==0){r=p;fa[p]=pre;return;}
 49     if(X[p]<=X[r]+eps)Insert(ch[r][0],r,p);
 50     else Insert(ch[r][1],r,p);
 51 }
 52 
 53 void Update(int p){
 54     Splay(p);
 55     if (ch[p][0]){
 56         int l=Get_Prev();
 57         Splay(l,p);ch[l][1]=0;
 58         lk[p]=rk[l]=Get_K(p,l);
 59     }
 60     else lk[p]=INF;
 61     if (ch[p][1]){
 62         int r=Get_Succ();
 63         Splay(r,p); ch[r][0]=0;
 64         rk[p]=lk[r]=Get_K(r,p);
 65     }
 66     else rk[p]=-INF;
 67     if (lk[p]<=rk[p]+eps){
 68         rt=ch[p][0]; ch[rt][1]=ch[p][1]; fa[ch[p][1]]=rt; fa[rt]=0;
 69         rk[rt]=lk[ch[p][1]]=Get_K(ch[rt][1],rt);
 70     }
 71 } 
 72 
 73 int Get_Pos(double k){
 74     int p=rt;
 75     while(p){
 76         if(lk[p]+eps>=k&&k+eps>=rk[p])break;
 77         if(lk[p]<k+eps)p=ch[p][0];
 78         else p=ch[p][1];
 79     }
 80     return p;
 81 }
 82 
 83 double Get_Ans(double a,double b){
 84     int p=Get_Pos(-b/a);
 85     return a*Y[p]+b*X[p];
 86 }
 87 
 88 int main(){
 89 #ifndef ONLINE_JUDGE
 90     freopen("cash.in","r",stdin);
 91     freopen("cash.out","w",stdout);
 92 #endif
 93     double a,b,rate;
 94     scanf("%d%lf",&n,&ans);
 95     for(int i=1;i<=n;i++){
 96         scanf("%lf%lf%lf",&a,&b,&rate);
 97         if(i!=1)ans=max(ans,Get_Ans(a,b));
 98         X[i]=ans/(rate*a+b);
 99         Y[i]=X[i]*rate;
100         Insert(rt,0,i);
101         Update(i);    
102     }
103     printf("%.3f\n",ans);
104     return 0;
105 }

 

转载于:https://www.cnblogs.com/TenderRun/p/5307998.html

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

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

相关文章

ArcGIS 10.2晕渲图+旋转图制作

晕渲图-通过模拟实际地面本影与落影的方法反映实际地形起伏特征的一种重要的地形图。晕渲图是DEM地表形态表达的一种形式,它通过设置光源的高度角和方位角更形象或者更符合人类视觉的方式展示一个地区的地形。通过晕渲图,可以很好的反应地形地势的变化,有很好的立体感,方便…

unity5.x C# 获取屏幕宽度 设置不受重力影响

在unity5.x中&#xff0c;获取屏幕宽度代码如下&#xff1a; float screenWeight Screen.width; //获取屏幕宽度 Screen.width 在此获取屏幕的宽度&#xff0c;从而赋值给screenWeight变量。 在unity5.x中在inspector中可以设置是否当前游戏对象是否受重力影响&…

sort命令详解及Nginx统计运用

sort命令是帮我们依据不同的数据类型进行排序&#xff0c;其语法及常用参数格式&#xff1a;  sort [-bcfMnrtk][源文件][-o 输出文件] 补充说明&#xff1a;sort可针对文本文件的内容&#xff0c;以行为单位来排序。参  数&#xff1a; -b 忽略每行前面开始出的空格字符…

php扩展开发1--添加函数

目标&#xff1a;便携php扩展 要求实现 输出hello word 首先用的是php7.0.3 centos7.1或者centos6. 1.1 RPM安装PHP rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpmyum install php70wphp -v 看一下 7.0.3php -m 看一下 php70w-devel, php70w-opcache模…

.NET5停止支持,难道就是没前途?

一篇微软官博引发热议&#xff0c;《2022年5月8号.NET5.0将正式停止支持》&#xff0c;此事在.NET5发布时就已经定下来的&#xff0c;文章不过是重申了一下事实&#xff0c;结果却成为某些人眼中的 ”瞎折腾“ ”不靠谱“ ”没前途“&#xff0c;真是无语。技术的更新迭代才是生…

lintcode 418整数转罗马数字

描述 给定一个整数&#xff0c;将其转换成罗马数字。 返回的结果要求在1-3999的范围内。 说明 https://en.wikipedia.org/wiki/Roman_numeralshttps://zh.wikipedia.org/wiki/%E7%BD%97%E9%A9%AC%E6%95%B0%E5%AD%97http://baike.baidu.com/view/42061.htm样例 思路 while循环拆…

linux进程上下文切换,Linux 性能分析总结之 CPU 上下文切换(二)

0x00 前言上一篇笔记中我讲到了&#xff0c;在寻找 CPU 的性能瓶颈的问题的时候&#xff0c;首先会查看整台机器的平均负载是否高&#xff0c;然后再使用 pidstat 等工具判断到底是哪种情况导致的平均负载升高&#xff0c;主要情况有三种&#xff1a;CPU 密集型IO 密集型大量进…

​ArduinoYun教程之ArduinoYun硬件介绍

2019独角兽企业重金招聘Python工程师标准>>> ArduinoYun教程之ArduinoYun硬件介绍 ArduinoYun的电源插座 Arduino Yun有两排插座&#xff0c;这些插座可以按类型分为三类&#xff1a;电源、数字IO和模拟输入。电源部分主要集中在如图1.7所示的部分。 图1.7 电源集中…

.NET Nuget包 汉化工具

汉化前汉化后一键汉化附带150M数据库&#xff0c;包含.NET6及EFCore等常用库的翻译数据&#xff0c;可离线运行。使用时建议注册一个百度翻译的账号。注册地址 https://fanyi-api.baidu.com/。注意: 不是“百度云”!!! 不是“百度云”!!! 不是“百度云”!!!是“百度翻译”&…

Apache错误日志提示AH02004: SSL Proxy: Peer certificate is expired

1 、问题 apache错误日志提示如下 AH02004: SSL Proxy: Peer certificate is expired 接下来日志会打印ssl握手失败 然后抓包分析的时候错误提示如下 Level: Fatal, Description: Certificate Unkonw 2 、open ssl命令探测服务器证书日期 我们用open ssl命令探测服务器证书…

【ArcGIS遇上Python】窗体版Python批量处理地理数据--栅格裁剪

一、说明 之前写过用Python代码块处理地理数据的例子,如裁剪、投影、格式转换等,曾想过用C#制作个窗体,嵌入Python代码,今天无意发现Python也能用tKinter构建简单的窗体,眼前一亮,先写个批量裁剪的例子吧。这样就不用对数据路径改来改去了,只需确定元数据路径,掩膜数据…

缺少linux内核,Linux内核缺页

整个缺页异常的处理过程非常复杂&#xff0c;我们这里只简单介绍一下缺页涉及到的内核函数。当CPU产生一个异常时&#xff0c;将会跳转到异常处理的整个处理流程中。对于缺页异常&#xff0c;CPU将跳转到page_fault异常处理程序中&#xff0c;该异常处理程序会调用do_page_faul…

简单好用的Adapter---ArrayAdapter

2019独角兽企业重金招聘Python工程师标准>>> ListView中比较简单但又非常方便的ArrayAdapter。 ArrayAdapter是BaseAdapter的派生类&#xff0c;在BaseAdapter的基础上&#xff0c;添加了一项重大的功能:可以直接使用泛型构造。 先来看一个简单的例子: Overrideprot…

表单数据自动录入_Excel总表录入、分表自动更新,只要数据透视表和一个快捷键就行...

合并多个分表到一个总表中&#xff0c;这样的操作很常见。但&#xff0c;有时候我们也需要反过来&#xff0c;即将一个总表拆分成多个子表&#xff0c;并且在总表中录入/修改数据后&#xff0c;每个分表都可以自动更新数据。如以下资金流动表。除了资金流水&#xff0c;我们还特…

.net Core中如何限制接口请求次数

.net core中如何限制接口请求次数像AspNetCoreRateLimit这种轮子我前面有给大家介绍过&#xff0c;今天就不说了&#xff0c;我们来聊聊背后的原理&#xff0c;欢迎各位大佬指正&#xff01;像我们经常看的一些APi请求接口网站&#xff1a;拿请求国外主要城市的七日接口举例&am…

linux之setsid命令

1 setsid命令 setsid主要是重新创建一个session,子进程从父进程继承了SessionID、进程组ID和打开的终端,子进程如果要脱离父进程&#xff0c;不受父进程控制&#xff0c;我们可以用这个setsid命令 2 测试 比如我们ping baidu.com setsid ping baidu.com 这个时候我们再ctrl…

【深入JAVA】java注解

在阅读的过程中有不论什么问题&#xff0c;欢迎一起交流 邮箱&#xff1a;1494713801qq.com QQ&#xff1a;1494713801 1、什么是java注解 注解&#xff0c;顾名思义&#xff0c;注解,就是对某一事物进行加入凝视说明&#xff0c;会存放一些信息。这些信息可能对以后某…

vlan跨交换机 udp广播_【详解】VLAN和VXLAN有何区别?VXLAN运用场景有哪些?

随着网络技术的发展&#xff0c;云计算凭借其系统利用率高、人力/管理成本低以及灵活性/扩展性方面展现的优势&#xff0c;已经成为目前各大行业IT建设的新趋势。而服务器的虚拟化作为云计算的核心技术之一&#xff0c;也得到了越来越多的应用&#xff0c;从而极大的增加了数据…

Android开源项目SlidingMenu本学习笔记(两)

我们已经出台SlidingMenu使用&#xff1a;Android开源项目SlidingMenu本学习笔记&#xff08;一个&#xff09;&#xff0c;接下来再深入学习下。依据滑出项的Menu切换到相应的页面 文件夹结构&#xff1a; 点击Bluetooth能够切换到对应的界面 关键代码 MainActivity.java pack…

扒开系统调用的三层皮(下)

5234 原创作品转载请注明出处 《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000 1.给MenuOS增加time和time-asm命令 步骤 rm menu -rf //强制删除git clonehttp://github.com/menging/menu.git // 克隆相关信息到menucd menumake rootfs //自动编…