【题目链接】

http://www.lydsy.com/JudgeOnline/problem.php?id=2726

【题意】

将n个任务划分成若干个块,每一组Mi任务花费代价(T+sigma{ tj }+s)*sima{ fi },j属于Mi,T为当前时间,问最小代价。

【思路】

设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

经过整理得到:

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

设X(i)=F[i],Y(i)=f[j]-F[n]*T[j]+F[j]*T[j]-s*F[j],a(i)=T[i]则有:

f[i]=min{ -a(i)*X(j)+Y(j) }

则我们需要:

min p = -a(i)*X(j)+Y(j)

即最小化直线方程:Y(j)=a(i)*X(j)+p的截距。

如果时间没有负数的话(出题人神脑洞<_<,这个题可以直接上单调队列维护下凸线。事实上这个算法可以得到60分。

有了负数以后因为斜率不满足随x单调,所以不能使用单调队列。

然后这道题就需要用splay或CDQ分治解。

Splay写法还是不会=-=,CDQ分治的处理和 这道题 类似,就不再赘述了。

需要注意的:x,y可能到达long long级别,所以不要直接除得slop

        运算过程中long long的标识。

        归并数组的时候几个小条件。

【代码】

 #include<set>
#include<cmath>
#include<queue>
#include<vector>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define trav(u,i) for(int i=front[u];i;i=e[i].nxt)
#define FOR(a,b,c) for(int a=(b);a<=(c);a++)
#define rep(a,b,c) for(int a=(b);a>=(c);a--)
using namespace std; typedef long long ll;
const int N = 5e5+;
const ll inf = 1e18; ll read() {
char c=getchar();
ll f=,x=;
while(!isdigit(c)) {
if(c=='-') f=-; c=getchar();
}
while(isdigit(c))
x=x*+c-'',c=getchar();
return x*f;
} struct Pt
{
ll x,y,k;
int id;
bool operator < (const Pt& rhs) const
{
return k<rhs.k;
}
}q[N],t[N]; bool cmp(const Pt& a,const Pt& b)
{
return a.x<b.x || a.x==b.x&&a.y<b.y;
} int T[N],F[N],st[N],top,n,s; ll f[N]; ll U(int j,int k)
{
return (ll)q[k].y-q[j].y;
}
ll D(int j,int k)
{
return (ll)q[k].x-q[j].x;
} void solve(int l,int r)
{
if(l==r) {
q[l].x=(ll)F[l];
q[l].y=(ll)f[l]-(ll)F[n]*T[l]+(ll)F[l]*T[l]-(ll)s*F[l];
return ;
}
int mid=l+r>>;
int l1=l,l2=mid+;
FOR(i,l,r) {
if(q[i].id>mid) t[l2++]=q[i];
else t[l1++]=q[i];
}
memcpy(q+l,t+l,sizeof(Pt)*(r-l+));
solve(l,mid);
top=;
FOR(i,l,mid) {
while(top> && (ll)U(st[top-],st[top])*D(st[top-],i)>(ll)U(st[top-],i)*D(st[top-],st[top])) top--;
st[++top]=i;
}
int j=;
FOR(i,mid+,r) {
while(j<top && U(st[j],st[j+])<(ll)q[i].k*D(st[j],st[j+])) j++;
f[q[i].id]=min(f[q[i].id],-(ll)q[i].k*q[st[j]].x+q[st[j]].y+(ll)F[n]*(T[q[i].id]+s));
}
solve(mid+,r);
l1=l,l2=mid+;
FOR(i,l,r) {
if((l2>r||cmp(q[l1],q[l2]))&&l1<=mid) t[i]=q[l1++];
else t[i]=q[l2++];
}
memcpy(q+l,t+l,sizeof(Pt)*(r-l+));
} int main()
{
// freopen("in.in","r",stdin);
// freopen("out.out","w",stdout);
n=read(),s=read();
FOR(i,,n)
T[i]=read(),T[i]+=T[i-],
F[i]=read(),F[i]+=F[i-];
FOR(i,,n) {
q[i].id=i;
q[i].k=T[i];
f[i]=inf;
}
sort(q+,q+n+);
solve(,n);
printf("%lld\n",f[n]);
return ;
}

简单DP(20分)

 #include<set>
#include<cmath>
#include<queue>
#include<vector>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define trav(u,i) for(int i=front[u];i;i=e[i].nxt)
#define FOR(a,b,c) for(int a=(b);a<=(c);a++)
#define rep(a,b,c) for(int a=(b);a>=(c);a--)
using namespace std; typedef long long ll;
const int N = 2e5+;
const ll inf = 1e18+; ll read() {
char c=getchar();
ll f=,x=;
while(!isdigit(c)) {
if(c=='-') f=-; c=getchar();
}
while(isdigit(c))
x=x*+c-'',c=getchar();
return x*f;
} ll T[N],F[N],f[N],pre[N],n,s; int main()
{
freopen("in.in","r",stdin);
freopen("outr.out","w",stdout);
n=read(),s=read();
FOR(i,,n)
T[i]=read(),T[i]+=T[i-],F[i]=read(),F[i]+=F[i-] ;
FOR(i,,n) {
f[i]=inf;
FOR(j,,i-) {
//f[i]=min(f[i],f[j]+(F[n]-F[j])*(T[i]-T[j]+s));
int tmp=-T[i]*F[j]+(f[j]-F[n]*T[j]+F[j]*T[j]-s*F[j]);
if(tmp<f[i]) pre[i]=j,f[i]=tmp;
}
f[i]+=F[n]*(T[i]+s);
}
printf("%lld\n",f[n]);
//FOR(i,1,n) {
// printf("%d %d\n",F[i],f[i]-F[n]*T[i]+F[i]*T[i]-s*F[i]);
//}
return ;
}

bzoj 2726 [SDOI2012]任务安排(斜率DP+CDQ分治)的更多相关文章

  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. BZOJ 2726 [SDOI2012] 任务安排 - 斜率优化dp

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

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

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

  5. BZOJ 2726: [SDOI2012]任务安排( dp + cdq分治 )

    考虑每批任务对后面任务都有贡献, dp(i) = min( dp(j) + F(i) * (T(i) - T(j) + S) ) (i < j <= N)  F, T均为后缀和. 与j有关 ...

  6. bzoj 2244 [SDOI2011]拦截导弹(DP+CDQ分治+BIT)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2244 [题意] 给定n个二元组,求出最长不上升子序列和各颗导弹被拦截的概率. [思路] ...

  7. bzoj 1492 [NOI2007]货币兑换Cash(斜率dp+cdq分治)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1492   [题意] 有AB两种货币,每天可以可以付IPi元,买到A券和B券,且A:B= ...

  8. bzoj 2726: [SDOI2012]任务安排

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

  9. 斜率dp cdq 分治

    f[i] = min { f[j] + sqr(a[i] - a[j]) } f[i]= min { -2 * a[i] * a[j] + a[j] * a[j] + f[j] } + a[i] * ...

随机推荐

  1. jmeter 常用内置变量

    1. vars   API:http://jmeter.apache.org/api/org/apache/jmeter/threads/JMeterVariables.html vars.get(& ...

  2. 佣金维护测试sql

    SELECT bmc.memberid , case then decode(bmc.source, , , 'TOPfitIBL') ELSE decode(bmc.source, , , 'TOP ...

  3. mysql索引建多了有什么坏处

    建立索引常用的规则如下: 1.表的主键.外键必须有索引: 2.数据量超过300的表应该有索引:3.经常与其他表进行连接的表,在连接字段上应该建立索引: 4.经常出现在Where子句中的字段,特别是大表 ...

  4. MySQL数据库中varchar与char类型的区别

    在数据库中建表时,需要给数据定义一个数据库中的数据库类型,当需要给String类型定义一个数据库中的类型时,可以看见有两个选择,一个是varchar,另一个是char,有很多人不清楚两者的区别,包括自 ...

  5. 微信小程序组件 模块化错和叹号

    wxml 页面 <import src="/pages/lianxi/lianxi.wxml" />  //引入文件 <view style='position: ...

  6. 熟悉常用Linux操作

    cd命令:切换目录 (1)切换到目录 /usr/local cd /usr/local (2)去到目前的上层目录 cd .. (3)回到自己的主文件夹 cd ~ ls命令:查看文件与目录 (4)查看目 ...

  7. Acdream1311_Apple

    无聊的时候看到上一次acdream群赛的一个题目,中间居然是有alice和bob的博弈题目,于是就去做了. 给n,m,两人轮流操作,每次操作可以使n+1,或者m+1,谁操作后满足nm>=A,那么 ...

  8. java 构造器二

  9. PGM学习之四 Factor,Reasoning

    通过上一篇文章的介绍,我们已经基本了解了:Factor是组成PGM模型的基本要素:Factor之间的运算和推理是构建高维复杂PGM模型的基础.那么接下来,我们将重点理解,Factor之间的推理(Rea ...

  10. linux eclipse add desktop shortcut with root permission

    gedit ~/.local/share/applications/opt_eclipse.desktop sudo apt-get install gksu [Desktop Entry] Type ...