机器学习题

题目大意

数据范围


题解

学长说是决策单调性?

直接斜率优化就好了嘛

首先发现的是,$A$和$B$的值必定是某两个$x$值。

那么我们就把,$y$的正负分成两个序列,$val1_i$表示$A$取序列中第$i$个数的值是,给的代价,$val2_i$同理。

那么最终的答案情况就是一个$i$一个$j$,分别是$val1_i + val2_j + a_i.x^2 + b_j.x^2 - 2*a_i.x\times b_j.x$。

显然可以斜率优化。

把第一个数列里的所有数抽象成点,为$(-2*a_i.x , val1_i + a_i.x^2)$。

弄一个下凸包,$B$递增枚举然后在凸包上切就好了。

但是,由于我们有一步排序,所以复杂度是$O(nlogn)$。

代码

#include<bits/stdc++.h>

#define N 500010 

using namespace std;

typedef long long ll;

ll bfr[N], aft[N], g[N], f[N], ans = 1e18;

int n, head, tail, m, x[N], y[N], id[N], p[N], q[N], b[N];

char *p1, *p2, buf[100000];

#define nc() (p1 == p2 && (p2 = (p1 = buf) + fread(buf, 1, 100000, stdin), p1 == p2) ? EOF : *p1 ++ )

int rd() {
int x = 0, f = 1;
char c = nc();
while (c < 48) {
if (c == '-')
f = -1;
c = nc();
}
while (c > 47) {
x = (((x << 2) + x) << 1) + (c ^ 48), c = nc();
}
return x * f;
} inline double slove(int i, int j) {
return 1.0 * (g[i] - g[j]) / (p[i] - p[j]);
} inline ll sqr(int x) {
return 1ll * x * x;
} int main() {
n = rd();
for (int i = 1; i <= n; i ++ )
b[i] = x[i] = rd(), y[i] = rd();
sort(b + 1, b + n + 1);
m = unique(b + 1, b + n + 1) - b - 1;
p[1] = b[1] - 1;
p[m + 2] = b[m] + 1;
for (int i = 1; i <= m; i ++ )
p[i + 1] = b[i];
for (int i = 1, k; i <= n; i ++ ) {
k = lower_bound(b + 1, b + m + 1, x[i]) -b;
bfr[k + 1] += max(-y[i], 0);
aft[k + 1] += max(y[i], 0);
}
n = m + 2;
for (int i = 1; i <= n; i ++ )
bfr[i] += bfr[i - 1];
for (int i = n; i; i -- )
aft[i] += aft[i + 1];
for (int i = 1; i <= n; i ++ )
g[i] = bfr[i - 1] + sqr(p[i]);
head = 1, tail = 0;
for (int i = 1; i <= n; i ++ ) {
while (head < tail && slove(q[tail - 1], q[tail]) >= slove(q[tail - 1], i))
tail -- ;
q[ ++ tail] = i;
while (head < tail && slove(q[head], q[head + 1]) <= 2 * p[i])
head ++ ;
f[i] = sqr(p[i] - p[q[head]]) + bfr[q[head] - 1] + aft[i + 1];
ans = min(ans, f[i]);
}
cout << ans << endl ;
return 0;
}

小结:形式比较明显,斜率优化非常显然。还是要学一下决策单调性才行.....

[Comet OJ - Contest #7 D][52D 2417]机器学习题_斜率优化dp的更多相关文章

  1. Comet OJ - Contest #6 D. 另一道树题 并查集 + 思维 + 计数

    Code: #include <cstdio> #include <algorithm> #include <cstring> #include <vecto ...

  2. Comet OJ - Contest #2 简要题解

    Comet OJ - Contest #2 简要题解 cometoj A 模拟,复杂度是对数级的. code B 易知\(p\in[l,r]\),且最终的利润关于\(p\)的表达式为\(\frac{( ...

  3. Comet OJ - Contest #2简要题解

    Comet OJ - Contest #2简要题解 前言: 我没有小裙子,我太菜了. A 因自过去而至的残响起舞 https://www.cometoj.com/contest/37/problem/ ...

  4. Comet OJ - Contest #4--前缀和

    原题:Comet OJ - Contest #4-B https://www.cometoj.com/contest/39/problem/B?problem_id=1577传送门 一开始就想着暴力打 ...

  5. Comet OJ - Contest #11 题解&赛后总结

    Solution of Comet OJ - Contest #11 A.eon -Problem designed by Starria- 在模 10 意义下,答案变为最大数的最低位(即原数数位的最 ...

  6. Comet OJ - Contest #8

    Comet OJ - Contest #8 传送门 A.杀手皇后 签到. Code #include <bits/stdc++.h> using namespace std; typede ...

  7. Comet OJ - Contest #13-C2

    Comet OJ - Contest #13-C2 C2-佛御石之钵 -不碎的意志-」(困难版) 又是一道并查集.最近做过的并查集的题貌似蛮多的. 思路 首先考虑,每次处理矩形只考虑从0变成1的点.这 ...

  8. Comet OJ - Contest #13 「火鼠的皮衣 -不焦躁的内心-」

    来源:Comet OJ - Contest #13 芝士相关: 复平面在信息学奥赛中的应用[雾 其实是道 sb 题??? 发现原式貌似十分可二项式定理,然后发现确实如此 我们把 \(a^i\) 替换成 ...

  9. Comet OJ - Contest #13 「佛御石之钵 -不碎的意志-」(hard)

    来源:Comet OJ - Contest #13 一眼并查集,然后发现这题 tmd 要卡常数的说卧槽... 发现这里又要用并查集跳过访问点,又要用并查集维护联通块,于是开俩并查集分别维护就好了 一开 ...

随机推荐

  1. 001_C/C++笔试题_考察C/C++语言基础概念

    (一)文章来自:C/C++笔试题-主要考察C/C++语言基础概念.算法及编程,附参考答案 (二)基础概念 2. 头文件中的ifndef/define/endif的作用? 答:防止该头文件被重复引用. ...

  2. SQL Server 基础:朝花夕拾

    序言 INSERT INTO SELECT 与 SELECT INTO 通俗来讲,INSERT INTO SELECT 和 SELECT INTO 两个语句的作用都是复制表,因为都是从一个表中查询出数 ...

  3. luogu 2294 [HNOI2005]狡猾的商人 差分约束

    一个差分约束模型,只需判一下有没有负环即可. #include <bits/stdc++.h> #define N 103 #define M 2004 #define setIO(s) ...

  4. 百度智能api接口汇总

    一:自然语言处理 # -*- coding: utf-8 -*- # @Author : FELIX # @Date : 2018/5/18 9:47 # pip install baidu-aip ...

  5. springboot 生产环境与开发环境配置

    通过修改yml文件里的active属性,prod(生产环境) 与 dev (开发环境)

  6. 无法连接虚拟设备 ide1:0及上不网

    无法连接虚拟设备 ide1:0 问题: 启动vmware之后,发现出现无法连接 ide 1:0. 网络查找之后,发现是之前挂载的iso镜像找不到了. 原因: 我把iso镜像放到其他位置. 解决: 指定 ...

  7. LVS集群之IP TUN模式以及网站压力测试

    今天来看一下LVS的第三种模式IP TUN. TUN方式,是通过给数据包加上新的IP头部来实现,这个可以跨整个广域网. 环境: 主机名 IP 系统 角色 tiandong63 RIP:192.168. ...

  8. SDN上机第4次作业

    1. 解压安装OpenDayLight控制器(本次实验统一使用Beryllium版本) 1)JDK的安装与环境配置 ​ 嗯,装这个东西还得先装JDK: ​ 在线真人手把手教你安装jdk ​ 输入sud ...

  9. sentinel备忘

    git https://github.com/alibaba/Sentinel   https://github.com/dubbo/dubbo-sentinel-supportdubbo http: ...

  10. AB窗体互传参数本质

    一.找了好几个,都不靠谱,不是说不靠谱,自己感觉太繁琐,根本就是本窗体的属性(对象)的传递,1实例化2把实例化后的窗体属性=本窗体的对象 二.传递的的时候都是在互相引用的时候传递,推荐的个人认为最简单 ...