洛谷P3195 玩具装箱
第一道斜率优化题。
首先一个基本的状态转移方程是

要使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 玩具装箱的更多相关文章
- 洛谷P3195 玩具装箱TOY
题目大意: 有n个数,要将他们分成若干段,每一段的cost定义为: cost=r-l+ΣCk (k∈[r,l]) 该段的最终花费是:(cost-L)^2; 给出L,n,C(1~n),总共的最小花费. ...
- 洛谷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: ...
- 洛谷 P3195 [HNOI2008] 玩具装箱
链接: P3195 题意: 给出 \(n\) 个物品及其权值 \(c\),连续的物品可以放进一个容器,如果将 \(i\sim j\) 的物品放进一个容器,产生的费用是 \(\left(j-i+\sum ...
- 洛谷P3195 [HNOI2008] 玩具装箱 [DP,斜率优化,单调队列优化]
题目传送门 题目描述 P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一种特殊的一维容器中.P教授有编号为1...N ...
- 洛谷P3195 [HNOI2008]玩具装箱TOY——斜率优化DP
题目:https://www.luogu.org/problemnew/show/P3195 第一次用斜率优化...其实还是有点云里雾里的: 网上的题解都很详细,我的理解就是通过把式子变形,假定一个最 ...
- 洛谷P3195 [HNOI2008]玩具装箱TOY(单调队列优化DP)
题目描述 P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一种特殊的一维容器中.P教授有编号为1...N的N件玩具, ...
- [洛谷P3195][HNOI2008]玩具装箱TOY
题目大意:有n个物体,大小为$c_i$.把第i个到第j个放到一起,容器的长度为$x=j-i+\sum\limits_{k-i}^{j} c_k$,若长度为x,费用为$(x-L)^2$.费用最小. 题解 ...
- 洛谷P3195 [HNOI2008]玩具装箱TOY 斜率优化
Code: #include<cstdio> #include<algorithm> using namespace std; const int maxn = 100000 ...
- 洛谷 P3195 [HNOI2008]玩具装箱TOY
题意简述 有n个物体,第i个长度为ci 将n个物体分为若干组,每组必须连续 如果把i到j的物品分到一组,则该组长度为 \( j - i + \sum\limits_{k = i}^{j}ck \) 求 ...
随机推荐
- Day 3-3 内置方法
常用内置函数方法: min,max li = [1, 2, 3, 6, 9, 5, 10, 26] print('li的最小值是:', min(li)) # 取最小值 print('li的最大值是:' ...
- Java 多线程概述
几乎所有的操作系统都支持同时运行多个任务,一 个任务通常就是一个程序,每个运行中的程序就是一个进程.当一个程序运行时,内部可能包含了多个顺序执行流,每个顺序执行流就是一个线程. 线程和进程 几乎所有的 ...
- oninput和onchange的区别
菜鸟教程: oninput事件:HTML5标准事件 当用户向<input>中尝试输入时执行JavaScript: <input type="text" oninp ...
- Ubuntu18.04安装mysql5.7
Ubuntu18.04安装mysql5.7 1.1安装 首先执行下面三条命令: # 安装mysql服务 sudo apt-get install mysql-server # 安装客户端 sudo a ...
- Python cmd库的简易使用
简单记录一下,竟然这么简单的方法就能在 python 里面实现一个简单的交互式命令行以前从来没有尝试过. 上一个完整的例子: import cmd import osimport readline r ...
- Python:matplotlib绘制条形图
条形图,也称柱状图,看起来像直方图,但完是两码事.条形图根据不同的x值,为每个x指定一个高度y,画一个一定宽度的条形:而直方图是对数据集进行区间划分,为每个区间画条形. 将上面的代码稍微修改一 ...
- Arrays类
package cn.zhou.com; import java.util.Arrays; /* * Arrays 类 ? * * 数组工具类 操作数组! * * Arrays的方法? * * */ ...
- SpringBoot之显示本地图片范例
controller // 扫描指定目录下的图片进行展示 @RequestMapping("/showPics") public ModelAndView showPics(Mod ...
- ABP 番外篇-容器
一. @using YD.CloudTimetable.Web.Areas.AppAreaName.Startup @{ ViewBag.CurrentPageName = AppAreaNamePa ...
- 一、纯css实现顶部进度条随滚动条滚动
一.效果图 二.直接复制粘贴 <!DOCTYPE html> <html lang="en"> <head> <meta charset= ...