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. Angular 过滤器

    <!DOCTYPE html><html ng-app="myApp"><head lang="en"> <meta ...

  2. display设置弹性盒布局

    转自:http://blog.csdn.net/itbwy/article/details/52648711 网页布局(layout)是CSS的一个重点应用. 布局的传统解决方案,基于盒状模型,依赖  ...

  3. CentOS6.8 安装配置Mysql

    1.下载mysql的repo源 wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm 2.安装mysql-commun ...

  4. Session和Cookie介绍及常见httpcode

    Cookie和Session,及常见httpcode 1.cookie和session简介: cookie是放在客户端的键值对,用来识别用户信息的,主要包括:名字,值,过期时间,路径和域.路径与域一起 ...

  5. JavaSE从入门到精通

      1.JavaSE的安装 windows下安装完成后,配置环境变量如下: JAVA_HOME       C:\Program Files (x86)\Java\jdk1.8.0_91 CLASSP ...

  6. Missing artifact com.oracle:ojdbc6:jar:11.2.0.3 Maven中不能引入ojdbc解决方法,错误

    今天从服务器检出Maven项目的时候,遇到了一个问题,就是在pom.xml中引入ojdbc的jar包的时候出错了,提示是Missing artifact com.oracle:ojdbc6:jar:1 ...

  7. 一、MyCat的搭建

    一.什么是mycat 简单直接点就是,MyCat其实就是一个数据库的中间件!一般我们都是app直接到数据库!有了MyCat以后,就是app到MyCat然后再访问数据库. mycat是个中间件,它负责连 ...

  8. crontab注意%

    %在其中有特殊含义表示开始新行 十分坑 例子:写一个定时任务用到date命令 crontab -e * * * * * date +%F >> /tmp/time.log 查看我们的cro ...

  9. node.js 运行机制与简单使用

    一.hello world 1.引入 required 模块 2.创建服务器 3.接收请求与响应请求 var http = require('http'); // 载入http模块 http.crea ...

  10. linux查找符合条件的文件并删除

    找到根目录下所有的以test开头的文件并把查找结果当做参数传给rm -rf命令进行删除: 1.find / -name “test*” |xargs rm -rf 2.find / -name “te ...