题解

本题的状态很容易设计:

f[i] 为到第i个物件的最小代价。

但是方程不容易设计,因为有“后效性”

有两种方法解决:

1)倒过来设计动态规划,典型的,可以设计这样的方程:

dp(i) = min( dp(j) + F(i) * (T(i) - T(j) + S) ) (i < j <= N) F, T均为后缀和. http://www.cnblogs.com/JSZX11556/p/5184251.html

2)提前计算代价,典型的,可以设计这样的方程:

「设f[i]为将前i个任务划分完成的最小费用,Ti Fi分别表示t和f的前缀和,则不难写出转移方程式:

    f[i]=min{ f[j]+(F[n]-F[j])*(T[i]-T[j]+s) },1<=j<=i-1」 ——来自神犇hahalidaxin学长

这里我采用了第二种方法,设计这样的方程:

f[i] = min{f[j] + S * (F[n]-F[j]) + T[i]*(F[i]-F[j]) }

其中,F,T均是前缀和。

这是一个(1D/1D)的方程,我们如果直接求解,O(n2)的复杂度,不能满足要求。

对于一个(1D/1D)的方程,一般采用斜率优化或者四边形不等式进行优化转移。我们考虑斜率优化。

令k < j < i ,如果j优于k,我们有:

f[k] - S * F[k] - T[i]F[k] > f[i] - S * F[j] - TiF[j]

进一步整理,

f[j]-f[k]+SF[k]-SF[j] < T[i]*(F[j] - F[k]),

考虑到F是前缀和,并且F没有负值,所以F[x]函数严格单调递增,F[j]-F[k] > 0, 我们两边同时除以(F[j]-F[k]),

(f[j]-f[k])

—————— - S < T[i]

(F[j] - F[k])

假设T[x]是单调的,我们可以直接通过单调队列转移,复杂度O(1),总复杂度O(n)。

但是这个题防AC的一个点是:T可以是负数,所以T[i]并不单调。

所以我们可以使用二分查找,付出O(logn)的时间复杂度,对于本题而言可以接受。 // 另外,听说本题还有使用“CDQ分治”解答的方法

所以我们就使用O(nlogn)的时间解决了这个问题。

代码

#include <bits/stdc++.h>
using namespace std;
const int maxn = 1e6+5;
#define ll long long
ll T[maxn], F[maxn], f[maxn];
int N, S;
int head, tail, q[maxn];
void dp() {
head = tail = 0;
for(int i = 1; i <= N; i++) {
int l = 0, r = tail;
while(l < r) {
ll mid = (l+r)/2;
if((ll)(f[q[mid+1]]-f[q[mid]]) >= (ll)(T[i]+S) * (F[q[mid+1]]-F[q[mid]])) r = mid;
else l = mid+1;
}
int j = q[l];
f[i] = f[j] + S*(F[N]-F[j])+T[i]*(F[i]-F[j]);
while(head < tail && (ll)(f[q[tail]]-f[q[tail-1]])*(F[i]-F[q[tail]]) >= (ll)(f[i]-f[q[tail]])*(F[q[tail]]-F[q[tail-1]]))
tail--;
q[++tail] = i;
}
}
int main() {
//freopen("input", "r", stdin);
scanf("%d %d", &N, &S);
for(int i = 1; i <= N; i++) {
scanf("%lld %lld", &T[i], &F[i]);
T[i] += T[i-1];
F[i] += F[i-1];
}
dp();
printf("%lld", f[N]);
return 0;
}

[bzoj2726][SDOI2012]任务安排 ——斜率优化,动态规划,二分,代价提前计算的更多相关文章

  1. BZOJ 2726: [SDOI2012]任务安排 [斜率优化DP 二分 提前计算代价]

    2726: [SDOI2012]任务安排 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 868  Solved: 236[Submit][Status ...

  2. 【BZOJ2726】[SDOI2012]任务安排 斜率优化+cdq分治

    [BZOJ2726][SDOI2012]任务安排 Description 机器上有N个需要处理的任务,它们构成了一个序列.这些任务被标号为1到N,因此序列的排列为1,2,3...N.这N个任务被分成若 ...

  3. [BZOJ2726][SDOI2012]任务安排(DP+凸壳二分)

    2726: [SDOI2012]任务安排 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1580  Solved: 466[Submit][Statu ...

  4. [SDOI2012]任务安排 - 斜率优化dp

    虽然以前学过斜率优化dp但是忘得和没学过一样了.就当是重新学了. 题意很简单(反人类),利用费用提前的思想,考虑这一次决策对当前以及对未来的贡献,设 \(f_i\) 为做完前 \(i\) 个任务的贡献 ...

  5. BZOJ 2726: [SDOI2012]任务安排 斜率优化 + 凸壳二分 + 卡精

    Code: #include<bits/stdc++.h> #define setIO(s) freopen(s".in","r",stdin) # ...

  6. BZOJ 2726 [SDOI2012] 任务安排 - 斜率优化dp

    题解 转移方程与我的上一篇题解一样 : $S\times sumC_j  + F_j = sumT_i \times sumC_j + F_i - S \times sumC_N$. 分离成:$S\t ...

  7. luoguP2365 任务安排 斜率优化 + 动态规划

    Code: #include<bits/stdc++.h> #define setIO(s) freopen(s".in","r",stdin) # ...

  8. BZOJ2726【SDOI2012】任务安排(斜率优化Dp+二分查找)

    由题目条件显然可以得到状态 f[i][j] 表示以 i 为结尾且 i 后作为断点,共做了 j 次分组的最小代价. 因此转移变得很显然:f[i][j]=min{f[k][j-1]+(s×j+sumT[i ...

  9. BZOJ2726 [SDOI2012]任务安排 【斜率优化 + cdq分治】

    题目 机器上有N个需要处理的任务,它们构成了一个序列.这些任务被标号为1到N,因此序列的排列为1,2,3...N.这N个任务被分成若干批,每批包含相邻的若干任务.从时刻0开始,这些任务被分批加工,第i ...

随机推荐

  1. Pandas基本命令

    关键缩写和包导入 在这个速查手册中,我们使用如下缩写: df:任意的Pandas DataFrame对象 同时我们需要做如下的引入: import pandas as pd 创建测试对象 import ...

  2. photoshop入门笔记2:PS箭头的制作

    ---恢复内容开始--- 1.     首先打开ps软件,在ps里新建一个画布这里就500*500,可以随意. 2.然后在ps软件界面上的工具栏里找到‘直线工具’,如图. 3.选择好工具之后,在ps软 ...

  3. C#简单的文件阅读器

    写一个简单的文件阅读器  1.可以读取大文件(2G)2.实现首页.下一页.前一页.末页的跳转3.实现到指定页面的跳转,比如跳转到第**页4.限制每页显示字符数 1029-4069byte,且用户可自定 ...

  4. Kubernetes-简介(一)

    简介 Kubernetes是一个开源.用于管理云平台中多个主机上的容器化的应用,目标是让部署容器化的应用简单并且高效,Kuernetes提供了应用部署.规划.更新.维护的一种机制. 在Kubernet ...

  5. 读懂CCS链接命令文件(.cmd)

    链接器的核心工作就是符号表解析和重定位,链接命令文件则使得编程者可以给链接器提供必要的指导和辅助信息.多数时候,由于集成开发环境的存在,开发者无需了解链接命令文件的编写,使用默认配置即可.但若需要对计 ...

  6. 5,Linux之文档与目录结构

    Linux文件系统结构 Linux目录结构的组织形式和Windows有很大的不同.首先Linux没有“盘(C盘.D盘.E盘)”的概念.已经建立文件系统的硬盘分区被挂载到某一个目录下,用户通过操作目录来 ...

  7. 15.5,centos下redis安全相关

      博文背景: 由于发现众多同学,在使用云服务器时,安装的redis3.0+版本都关闭了protected-mode,因而都遭遇了挖矿病毒的攻击,使得服务器99%的占用率!! 因此我们在使用redis ...

  8. NPM安装vue-cli,并创建vue+webpack项目模板

    1.安装npm npm 是node.js 的包管理工具, 安装流程地址:https://docs.npmjs.com/cli/install  估计会非常慢,我们可以使用淘宝NPM镜像下载安装:htt ...

  9. P1800 software_NOI导刊2010提高(06)(二分答案)

    P1800 software_NOI导刊2010提高(06) 题目描述 一个软件开发公司同时要开发两个软件,并且要同时交付给用户,现在公司为了尽快完成这一任务,将每个软件划分成m个模块,由公司里的技术 ...

  10. String类中的toCharArray()方法

    toCharArray()方法  该方法的作用是返回一个字符数组,该字符数组中存放了当前字符串中的所有字符 public class toChar1{ public static void main( ...