题目

\(N\) 个任务排成一个序列在一台机器上等待完成(顺序不得改变),这 \(N\) 个任务被分成若干批,每批包含相邻的若干任务。从时刻 \(0\) 开始,这些任务被分批加工,第 \(i\) 个任务单独完成所需的时间是 \(T_i\)。在每批任务开始前,机器需要启动时间 \(S\),而完成这批任务所需的时间是各个任务需要时间的总和(同一批任务将在同一时刻完成)。每个任务的费用是它的完成时刻乘以一个费用系数 \(F_i\)。请确定一个分组方案,使得总费用最小。

分析

可以使用费用提前计算的技巧,把后面的费用移到前面计算。

设 \(d_i\) 代表到前 \(i\) 个任务的最小代价:\(F,T\) 分别为 \(f,t\) 数组的前缀和

\[\begin{align*}
d_i & = \min_{j=0}^{i-1} \{d_j + S(F_n - F_j) + T_i (F_i - F_j)\} \\
& = \min_{j=0}^{i-1} \{d_j + S F_n - S F_j + T_i F_i - T_i F_j\} \\
& = \min_{j=0}^{i-1} \{d_j - S F_j - T_i F_j\} + T_i F_i + S F_n \\
\end{align*}
\]

令:\(b = d_j - ST_j - T_iF_j\), 则有:

\[\begin{align*}
b & = d_j - SF_j - T_iF_j\\
d_j - SF_j & = b + T_iF_j \\
\end{align*}
\]

令 \(y=d_j-SF_j\), \(x=F_j\), \(k = T_i\), 这就是我们常见的斜率优化式。

显然 \(T_i\) 单调递增。

代码

#include <bits/stdc++.h>

int const kMaxN = 1e6 + 5;

std::deque<int> que;
int d[kMaxN], f[kMaxN], t[kMaxN], F[kMaxN], T[kMaxN], S, n; inline int X(int i) {return F[i];}
inline int Y(int i) {return d[i] - S * F[i];}
inline double Slope(int i, int j) {return (Y(i) - Y(j)) / (double)(X(i) - X(j));} int main() {
memset(d, 0x3f, sizeof(d));
scanf("%d%d", &n, &S);
for(int i = 1; i <= n; i++) {
scanf("%d%d", t + i, f + i);
T[i] = T[i - 1] + t[i];
F[i] = F[i - 1] + f[i];
}
d[0] = 0;
que.push_back(0);
for(int i = 1; i <= n; i++) {
while(que.size() > 1 && Slope(que[0], que[1]) < T[i]) que.pop_front();
int j = que[0];
d[i] = d[j] + S * (F[n] - F[j]) + T[i] * (F[i] - F[j]);
while(que.size() > 1 &&
Slope(que.back(), i) < Slope(que.back(), que[que.size() - 2])
)
que.pop_back();
que.push_back(i);
}
printf("%d", d[n]);
return 0;
}

【IOI 2002/FJOI2019】任务安排(超级计算机)的更多相关文章

  1. POJ 1180 斜率优化DP(单调队列)

    Batch Scheduling Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 4347   Accepted: 1992 ...

  2. POJ 1054 The Troublesome Frog

    The Troublesome Frog Time Limit: 5000MS Memory Limit: 100000K Total Submissions: 9581 Accepted: 2883 ...

  3. IOI2002 POJ1054 The Troublesome Frog 讨厌的青蛙 (离散化+剪枝)

    Description In Korea, the naughtiness of the cheonggaeguri, a small frog, is legendary. This is a we ...

  4. POJ1180 Batch Scheduling 解题报告(斜率优化)

    题目链接:http://poj.org/problem?id=1180 题目描述: There is a sequence of N jobs to be processed on one machi ...

  5. P2365 任务安排 / [FJOI2019]batch(斜率优化dp)

    P2365 任务安排 batch:$n<=10000$ 斜率优化入门题 $n^{3}$的dp轻松写出 但是枚举这个分成多少段很不方便 我们利用费用提前的思想,提前把这个烦人的$S$在后面的贡献先 ...

  6. luogu P2365 任务安排(FJOI2019 batch)

    洛谷传送门 FJOI 日常原题 $2333$(似乎还不如 SDOI2012 任务安排 $2333$) 显然考虑 $dp$,这个是经典的把未来的代价先计算的 $dp$,然后才是斜率优化 一开始想状态时一 ...

  7. 《Linux及安全》实验安排

    SEED(SEcurity EDucation)项目由雪城大学杜文亮教授2002年创立,为计算机教学提供一套信息安全实验环境,目前已开发超过30个实验,涵盖广泛的安全原理,被全世界数百个高校采用. 实 ...

  8. POJ1158 城市交通Traffic lights IOI 1999 (最短路)

    POJ1158 城市交通Traffic lights IOI 1999 (最短路) (1) 问题描述(probolem) 在d城里交通的安排不同寻常,城中有路口和路口之间的道路,再任意两个不同的路口之 ...

  9. 51Nod 1428 活动安排问题

    51Nod   1428  活动安排问题 Link: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1428 1428 活 ...

随机推荐

  1. 编译安装PHP开发环境

    Linux 系统为 CentOS 7.2 1. 安装 Nginx 安装 Nginx 依赖包: # yum -y install zlib zlib-devel openssl openssl-deve ...

  2. 使用vue搭建项目(创建手脚架)

    第一步:切换到创建的目录 创建项目 vue cerate [model] 第二步:切换到创建好的项目,然后创建element vue add element 第三步:创建router vue add ...

  3. 【洛谷P3205】[HNOI2010]CHORUS 合唱队

    合唱队 区间DP f[l][r][0/1]表示生成目标序列中的区间[l,r],最后一个数是a[l]/a[r] 的方案数 边界: f[i][i][0]=1 转移: f[l][r][0]=(a[l]< ...

  4. 【luogu P1137 旅行计划】 题解

    题目链接:https://www.luogu.org/problemnew/show/P1137 topsort + DP #include <queue> #include <cs ...

  5. Android学习笔记_40_系统结构 目录结构

    1.系统结构: 一.应用程序层 Android平台不仅仅是操作系统,也包含了许多应用程序,诸如SMS短信客户端程序.电话拨号程序.图片浏览器.Web浏览器等应用程序.这些应用程序都是用Java语言编写 ...

  6. U盘安装centOS和下载地址

    使用到的材料: 1.centos-6.2 i386 minimal 下载地址:http://mirrors.163.com/centos/6.2/isos/i386/CentOS-6.2-i386-m ...

  7. mysql自连接

    自连接: -- 求7369员工编号,姓名,经理编号和经理姓名 select e1.empno,e1.ename,e2.empno,e2.ename from emp e1,emp e2 where e ...

  8. 用JS实现一个时钟的效果

    (效果图) 分两步进行的. 第一步:  要得到现在的 时 分 秒 但是这里面有一个小玄机 . 比如现在是 9点整      时针指向 9 是没错的 但是如果现在是 9点半   时针应该指向的是 9到1 ...

  9. orcal 数据库 maven架构 ssh框架 的全注解环境模版 maven中央仓库批量删除lastupdated文件后依然是lastupdated解决方法 mirror aliyun中央仓库

    批量删除文件,得用批处理文件,文件名随便,路径改成你的Repository,代码如下 rem 这里写你的仓库路径 set REPOSITORY_PATH=d:\repo rem 正在搜索... for ...

  10. c#解析分析SQL语句

    最近总结了c#一般的功能,然后自己在博文中写了很多东西.主要是在用途上面.能够解决一些问题.现在分各个组件和方向写完了.主要的内容写了demo,也写了自己的项目组件和模型. 最后一个SQL分析.其实在 ...