P3195 [HNOI2008]玩具装箱TOY

第一道斜率优化题。

首先一个基本的状态转移方程是

要使f[i]最小,即b最小。

对于每个j,可以表示为一个点。

然后我们取固定斜率时截距最小的即可,高中线性规划。

单调队列维护下凸包。

然后每次二分出j,转移。

记得给(0,L * L)赋初值。

记得开long long

++,--最好别随便用,编译器的不同会让你爆0...

 #include <cstdio>

 typedef long long LL;
const int N = ; LL sum[N], g[N], p[N], top;
LL f[N], y[N]; inline double slope(int i, int j) {
return ((double)(y[j] - y[i])) / (g[j] - g[i]);
} inline int get(int i) {
if(i == ) {
return ;
}
double k = 2.0 * g[i];
int l = , r = top, mid;
while(l < r) {
mid = (l + r) / ;
//printf("%lf %lf \n", slope(p[mid], p[mid + 1]), k);
if(slope(p[mid], p[mid + ]) < k) {
l = mid + ;
}
else {
r = mid;
}
}
//printf("i = %d r = %d j = %d \n", i, r, p[r]);
return p[r];
} int main() {
//freopen("in.in", "r", stdin);
LL n, L;
scanf("%lld%lld", &n, &L);
L++;
for(int i = ; i <= n; i++) {
LL x;
scanf("%lld", &x);
sum[i] = sum[i - ] + x;
g[i] = i + sum[i];
}
y[] = L * L;
for(int i = ; i <= n; i++) {
// f[i] = f[j] + (g[i] - g[j] - L) ^ 2
int j = get(i); f[i] = f[j] + (g[i] - g[j] - L) * (g[i] - g[j] - L);
y[i] = f[i] + (g[i] + L) * (g[i] + L);
//printf("y[%d] = %d \n", i, y[i]); p[++top] = i;
while(top > && slope(p[top - ], p[top - ]) >= slope(p[top - ], p[top])) {
p[top - ] = p[top];
top--;
}
} /*for(int i = 1; i <= n; i++) {
printf("%lld ", f[i]);
}
puts("");*/
printf("%lld", f[n]);
return ;
}

AC代码

[update20181208]今天又考了一次玩具装箱,发现了一个问题.......怎么能把点的坐标直接带入到斜截式里面啊!!!!

只知道y - y0 = k(x - x0),从来没听过y0 = kx0 + b啊啊啊!!!

关于上面那个的解释:(感谢某蒋姓巨佬为我讲解)

上面那个式子化简为2gi * gj + C = F(j)

考虑有某条直线过点(gj, F(j)),且方程为kx + b = y,其中k = 2gi

那么将点带入,可得:k * gj + b = F(j)

故上面那个等式即为直线的方程。

y - F(j) = 2gi(x - gj)

y - F(j) = 2gi * x - 2gi * gj

然后反正瞎搞一搞就行了啦我也不管了啊啊啊啊阿斜率优化好难啊啊我到底在写什么东西啊

洛谷P3195 玩具装箱的更多相关文章

  1. 洛谷P3195 玩具装箱TOY

    题目大意: 有n个数,要将他们分成若干段,每一段的cost定义为: cost=r-l+ΣCk (k∈[r,l]) 该段的最终花费是:(cost-L)^2; 给出L,n,C(1~n),总共的最小花费. ...

  2. 洛谷P3195||bzoj1010 [HNOI2008]玩具装箱TOY

    洛谷P3195 bzoj1010 设s数组为C的前缀和 首先$ans_i=min_{j<i}\{ans_j+(i-j-1+s_i-s_j-L)^2\}$ (斜率优化dp)参考(复读)https: ...

  3. 洛谷 P3195 [HNOI2008] 玩具装箱

    链接: P3195 题意: 给出 \(n\) 个物品及其权值 \(c\),连续的物品可以放进一个容器,如果将 \(i\sim j\) 的物品放进一个容器,产生的费用是 \(\left(j-i+\sum ...

  4. 洛谷P3195 [HNOI2008] 玩具装箱 [DP,斜率优化,单调队列优化]

    题目传送门 题目描述 P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一种特殊的一维容器中.P教授有编号为1...N ...

  5. 洛谷P3195 [HNOI2008]玩具装箱TOY——斜率优化DP

    题目:https://www.luogu.org/problemnew/show/P3195 第一次用斜率优化...其实还是有点云里雾里的: 网上的题解都很详细,我的理解就是通过把式子变形,假定一个最 ...

  6. 洛谷P3195 [HNOI2008]玩具装箱TOY(单调队列优化DP)

    题目描述 P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一种特殊的一维容器中.P教授有编号为1...N的N件玩具, ...

  7. [洛谷P3195][HNOI2008]玩具装箱TOY

    题目大意:有n个物体,大小为$c_i$.把第i个到第j个放到一起,容器的长度为$x=j-i+\sum\limits_{k-i}^{j} c_k$,若长度为x,费用为$(x-L)^2$.费用最小. 题解 ...

  8. 洛谷P3195 [HNOI2008]玩具装箱TOY 斜率优化

    Code: #include<cstdio> #include<algorithm> using namespace std; const int maxn = 100000 ...

  9. 洛谷 P3195 [HNOI2008]玩具装箱TOY

    题意简述 有n个物体,第i个长度为ci 将n个物体分为若干组,每组必须连续 如果把i到j的物品分到一组,则该组长度为 \( j - i + \sum\limits_{k = i}^{j}ck \) 求 ...

随机推荐

  1. 【学亮IT手记】jQuery callback方法实例

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <script sr ...

  2. synchronized无法禁止指令重排序的证明

    package demo.reorder; import java.util.concurrent.ExecutorService; import java.util.concurrent.Execu ...

  3. docker遇到的问题以及docker 操作镜像的基本操作

    root@localhost ~]# systemctl status docker.service ● docker.service - Docker Application Container E ...

  4. 简单JQuery+AJAX+Servlet的计算器实现

    index.jsp <%@ page language="java" contentType="text/html; charset=UTF-8" pag ...

  5. php 将数组转换网址URL参数

    $array =array ( 'id' =123, 'name' = 'dopost' );echo http_build_query( $array );//得到结果id=123name=dopo ...

  6. SCP传送文件时提示No ECDSA host key is known forx.x.x.x and you have requested strict checking.问题的解决办法

    在使用SCP向其他设备传送文件时,打印如下错误: No ECDSA host key is known for x.x.x.x and you have requested strict checki ...

  7. java 中 Math类

    package cn.liuliu.com; import java.math.BigDecimal; import java.math.BigInteger; /* * 一.Math类? * * 1 ...

  8. Jenkins+PowerShell持续集成环境搭建(一)前期准备

    0. 系统要求 Windows Server:本文章使用的为Windows Server 2012 JDK:本文章使用为JDK 1.8 Windows PowerShell:本文章使用为PowerSh ...

  9. murongxixi的凸优化笔记

    http://www.cnblogs.com/murongxixi/p/3598645.html 在前两节里已经涉及到集合的相对内部与闭包的概念,这一节我们深入研究它们的性质和计算,之后介绍凸函数的连 ...

  10. EasyUI-datebox设置开始日期小于结束日期,并且结束日期小于当前日期

    datebox设置开始日期小于结束日期,并且结束日期小于当前日期 //日期控制扩展选择日期小于等于当前日期,开始日期小于等于结束日期 $("#datebox1").datebox( ...