斜率在转移顺序下不满足单调性的斜率优化\(DP\),用动态凸包来维护。送命题。

简化版题意:每次在凸包上插入一个点,以及求一条斜率为\(K\)的直线与当前凸包的交点。思路简单实现困难。

\(P.s\),不是特别建议用\(Set\)来维护动态凸包,万一中间哪一点功能实现\(STL\)没有提供就\(GG\)了。(比如要有两种比较运算符。)本人因此重构了三次\(:)\)

代码来源:黄学长的代码的魔改版。

#include <bits/stdc++.h>
using namespace std; const double eps = 1e-8;
const int N = 100000 + 5; int n, top, sta[N]; double f[N]; struct point {
double x, y, a, b, k, rate; int w, id;
}p[N], t[N]; double getk (int a, int b) {
if (b == 0) return -1e20;
if (fabs (p[a].x - p[b].x) < eps) {
return 1e20;
} else {
return (p[b].y - p[a].y) / (p[b].x - p[a].x);
}
} bool operator < (point a, point b) {
return a.k > b.k;
} void solve (int l, int r) {
if (l == r) {
f[l] = max (f[l], f[l - 1]);
p[l].y = f[l] / (p[l].a * p[l].rate + p[l].b);
p[l].x = p[l].rate * p[l].y;
return;
}//分治到底了显然我们可以直接计算出结果
int l1, l2, mid = (l + r) >> 1, j = 1;
//============================================================================
l1 = l; l2 = mid + 1;
for (int i = l; i <= r; i++) {
if (p[i].id <= mid) {
t[l1++] = p[i];
} else {
t[l2++] = p[i];
}
}
for (int i = l; i <= r; i++) {
p[i] = t[i];
}
solve (l, mid);//递归左边
top = 0;
for (int i = l; i <= mid; i++) {
while (top > 1 && getk (sta[top - 1], sta[top]) < getk (sta[top - 1], i) + eps) {
top--;
}
sta[++top] = i;
}//左边维护一个凸包
sta[++top] = 0;
for (int i = mid + 1; i <= r; i++) {
while (j < top && getk (sta[j], sta[j + 1]) + eps > p[i].k) {
j++;
}//用左边的点作为决策更新右边
f[p[i].id] = max (f[p[i].id], p[sta[j]].x * p[i].a + p[sta[j]].y * p[i].b);
}
solve (mid + 1, r);//递归右边
l1 = l; l2 = mid + 1;
for (int i = l; i <= r; i++) {
if (((p[l1].x < p[l2].x || (fabs(p[l1].x - p[l2].x) < eps && p[l1].y < p[l2].y)) || l2 > r) && l1 <= mid) {
t[i] = p[l1++];
} else {
t[i] = p[l2++];
}
}
for (int i = l; i <= r; i++) p[i] = t[i];
} int main () {
// freopen ("data.in", "r", stdin);
cin >> n >> f[0];
for (int i = 1; i <= n; i++) {
cin >> p[i].a >> p[i].b >> p[i].rate;
p[i].k = -p[i].a / p[i].b; p[i].id = i;
}
sort (p + 1, p + n + 1);//这里按照斜率进行排序,保证分治的每一块斜率是有序的
solve (1, n);
cout << fixed << setprecision (10) << f[n] << endl;
}

【BZOJ1492】【Luogu P4027】 [NOI2007]货币兑换 CDQ分治,平衡树,动态凸包的更多相关文章

  1. LUOGU P4027 [NOI2007]货币兑换 (斜率优化+CDQ分治)

    传送门 解题思路 题目里有两句提示一定要看清楚,要不全买要不全卖,所以dp方程就比较好列,f[i]=max(f[j]*rate[j]*a[i])/(rate[j]*a[j]+b[j])+(f[j]*b ...

  2. [NOI2007]货币兑换 cdq分治,斜率优化

    [NOI2007]货币兑换 LG传送门 妥妥的\(n \log n\)cdq做法. 这题用cdq分治也可以\(n \log n\)但是在洛谷上竟然比一些优秀的splay跑得慢真是见了鬼了看来还是人丑常 ...

  3. [NOI2007]货币兑换Cash(DP+动态凸包)

    第一次打动态凸包维护dp,感觉学到了超级多的东西. 首先,set是如此的好用!!!可以通过控制一个flag来实现两种查询,维护凸包和查找斜率k 不过就是重载运算符和一些细节方面有些恶心,90行解决 后 ...

  4. P4027 [NOI2007]货币兑换(斜率优化dp+cdq分治)

    P4027 [NOI2007]货币兑换 显然,如果某一天要买券,一定是把钱全部花掉.否则不是最优(攒着干啥) 我们设$f[j]$为第$j$天时用户手上最多有多少钱 设$w$为花完钱买到的$B$券数 $ ...

  5. 洛谷 P4027 [NOI2007]货币兑换 解题报告

    P4027 [NOI2007]货币兑换 题目描述 小 \(Y\) 最近在一家金券交易所工作.该金券交易所只发行交易两种金券:\(A\) 纪念券(以下简称 \(A\) 券)和 \(B\) 纪念券(以下简 ...

  6. 洛谷P4027 [NOI2007]货币兑换

    P4027 [NOI2007]货币兑换 算法:dp+斜率优化 题面十分冗长,题意大概是有一种金券每天价值会有变化,你可以在某些时间点买入或卖出所有的金券,问最大收益 根据题意,很容易列出朴素的状态转移 ...

  7. BZOJ_1492_[NOI2007]货币兑换Cash_CDQ分治+斜率优化

    BZOJ_1492_[NOI2007]货币兑换Cash_CDQ分治+斜率优化 Description 小Y最近在一家金券交易所工作.该金券交易所只发行交易两种金券:A纪念券(以下简称A券)和 B纪念券 ...

  8. LOJ 2353 & 洛谷 P4027 [NOI2007]货币兑换(CDQ 分治维护斜率优化)

    题目传送门 纪念一下第一道(?)自己 yy 出来的 NOI 题. 考虑 dp,\(dp[i]\) 表示到第 \(i\) 天最多有多少钱. 那么有 \(dp[i]=\max\{\max\limits_{ ...

  9. BZOJ1492 货币兑换 CDQ分治优化DP

    1492: [NOI2007]货币兑换Cash Time Limit: 5 Sec  Memory Limit: 64 MB Description 小Y最近在一家金券交易所工作.该金券交易所只发行交 ...

随机推荐

  1. Web(八) commons-fileupload上传下载

    在网上看见一篇不错的文章,写的详细. 以下内容引用那篇博文.转载于<http://www.cnblogs.com/whgk/p/6479405.html>,在此仅供学习参考之用. 一.上传 ...

  2. Python 的 Collection 库

    Collections 是 Python 内建的一个集合模块,提供了许多额外的数据类型. namedtuple namedtuple 主要用来生成可以使用名称来访问元素的数据对象,通常用来增强代码的可 ...

  3. Message的定义類型

    SAP通过Message来回执程序的执行状态.使用Tcode:SE91. SAP將Message分为不同的类,如下图显示为ZF环境下ZMM01类相关Message列表. Message short t ...

  4. mingw gcc 静态 static 编译 dav1d libdav1d.a

    export CC=/mingw/bin/gcc export CXX=/mingw/bin/g++ meson --prefix "/usr/local" build --bui ...

  5. mysql用sql语句创建表和数据 设置字符编码为utf-8

    简而言之 CREATE DATABASE xx CHARACTER SET utf8 COLLATE utf8_general_ci; USE xx; ),qname ) ) ) ) )); ) ,t ...

  6. 【HANA系列】SAP HANA使用XS和HTTP创建proxy

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[HANA系列]SAP HANA使用XS和HTT ...

  7. 解决ubuntu16.04 USB鼠标键盘使用卡顿

    小米游戏本,键盘突然M建不能用,去了售后换了个键盘. 小米售后真的不想吐槽……入坑 键盘鼠标卡顿由于挂起导致失灵,每次需要激活所以卡顿 解决办法如下: 编辑如下文件配置 sudo vim /etc/l ...

  8. kali安装redis

    下载 wget http://download.redis.io/releases/redis-4.0.11.tar.gz 解压 tar -zxvf redis-4.0.11.tar.gz 切换目录 ...

  9. 【神经网络与深度学习】基于Windows+Caffe的Minst和CIFAR—10训练过程说明

    Minst训练 我的路径:G:\Caffe\Caffe For Windows\examples\mnist  对于新手来说,初步完成环境的配置后,一脸茫然.不知如何跑Demo,有么有!那么接下来的教 ...

  10. Java网络爬虫

    一.前言 首先我们把准备工作做好:IDEA 2019.1.JDK1.8.Maven3.5 Jsoup的Maven依赖: <dependency> <groupId>org.js ...