●BZOJ 3963 [WF2011]MachineWorks
题链:
http://www.lydsy.com/JudgeOnline/problem.php?id=3963
题解:
斜率优化DP,CDQ分治。
先按时间排序。(规定以下内容的第i台机器的卖出时间D[i]大于第i-1台机器的卖出时间D[i-1])
定义DP[i]表示在在第i台机器可以交易的那天,卖出所有机器后能够得到的最大收益,(最后答案是DP[all_day+1])
转移显然:
$DP[i]=DP[i-1]$
$DP[i]=max(DP[j]+(D_i-D_j-1)*G_j-P_j+R_j) (j<i且DP[j]>=P[j])$
令$Y_j=DP[j]-(D_j+1)*G_j-P_j+R_j$,如果存在两个转移点k,j且G[k]<G[j],假设j点优于k点
那么 $Y_j-Y_k>-D_i(G_j-G_k)$
$\quad\quad\frac{Y_j-Y_k}{G_j-G_k}>-D_i$
那么得到结论,如果 G[k]<G[j],且Slope(j,k)>-D[i]的话,则j点优于k点。
同时如果存在三个转移来源点:k,j,i,满足G[k]<G[j]<G[i],
同时Slope(i,j)>Slope(j,k),则j点无效。
所以对于每个来源点二元组(G[j],Y[j]),只需要在平面上维护一个上凸壳即可。
但是G不单调,所以用CDQ分治。
对于分治的每一层l~r,先递归处理左边l~mid,然后把左边按G从小到大排序,并维护好上凸壳。
由于D单调递增,所以遍历一边凸壳以及右边mid+1~r进行贡献就好。
代码:
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define MAXN 100050
#define ll long long
using namespace std;
ll Y[MAXN],G[MAXN],D[MAXN],P[MAXN],R[MAXN],DP[MAXN];
int h[MAXN],N,C,T,S;
bool cmp(int i,int j){
return D[i]<D[j];
}
struct Moque{
int q[MAXN],l,r;
#define Slope(i,j) (1.0*(Y[i]-Y[j])/(G[i]-G[j]))
void Reset(){l=1; r=0;}
void Push(int i){
if(l<=r&&G[i]==G[q[r]])
{if(Y[i]>Y[q[r]]) r--; else return;}
while(l+1<=r&&Slope(i,q[r])>Slope(q[r],q[r-1])) r--;
q[++r]=i;
}
int Query(int i){
while(l+1<=r&&Slope(q[l+1],q[l])>-D[i]) l++;
return q[l];
}
}Q;
void solve(int l,int r){
static int tmp[MAXN],cl,cr,p; static ll MAXDP;
if(l==r) return (void)(Y[h[l]]=DP[h[l]]-(D[h[l]]+1)*G[h[l]]-P[h[l]]+R[h[l]]);
int mid=(l+r)>>1;
solve(l,mid);//之后,左边G单调
Q.Reset(); MAXDP=0;
for(int i=l;i<=mid;i++){
MAXDP=max(MAXDP,DP[h[i]]);
if(DP[h[i]]>=P[h[i]]) Q.Push(h[i]);//上凸壳斜率单减
}
//Di单增,-Di单减,正序枚举就好。
for(int i=mid+1,j;i<=r;i++){
j=Q.Query(h[i]);
DP[h[i]]=max(DP[h[i]],MAXDP);
DP[h[i]]=max(DP[h[i]],DP[j]+(D[h[i]]-D[j]-1)*G[j]-P[j]+R[j]);
}
solve(mid+1,r);
cl=l; cr=mid+1; p=l;
while(cl<=mid||cr<=r){
if(cl>mid) tmp[p]=h[cr],cr++;
else if(cr>r||G[h[cl]]<G[h[cr]]) tmp[p]=h[cl],cl++;
else tmp[p]=h[cr],cr++; p++;
}
for(int i=l;i<=r;i++) h[i]=tmp[i];
}
int main(){
int Cas=0;
while(1){
memset(DP,0,sizeof(DP));
scanf("%d%d%d",&N,&S,&T);
if(N==0&&DP[1]==0&&T==0) break;
memset(Y,0,sizeof(Y));
for(int i=1,a,b,c,d;i<=N;i++){
scanf("%d%d%d%d",&a,&b,&c,&d);
h[i]=i; D[i]=a; P[i]=b; R[i]=c; G[i]=d;
}
N++; D[N]=T+1; h[N]=N;
sort(h+1,h+N+1,cmp);
DP[h[1]]=S; solve(1,N);
printf("Case %d: %lld\n",++Cas,DP[N]);
}
return 0;
}
●BZOJ 3963 [WF2011]MachineWorks的更多相关文章
- HDU 3824/ BZOJ 3963 [WF2011]MachineWorks (斜率优化DP+CDQ分治维护凸包)
题面 BZOJ传送门(中文题面但是权限题) HDU传送门(英文题面) 分析 定义f[i]f[i]f[i]表示在iii时间(离散化之后)卖出手上的机器的最大收益.转移方程式比较好写f[i]=max{f[ ...
- BZOJ 3963: [WF2011]MachineWorks [CDQ分治 斜率优化DP]
传送门 当然了WF的题uva hdu上也有 你的公司获得了一个厂房N天的使用权和一笔启动资金,你打算在这N天里租借机器进行生产来获得收益.可以租借的机器有M台.每台机器有四个参数D,P,R,G.你可以 ...
- BZOJ 3963: [WF2011]MachineWorks 斜率优化 + splay动态维护凸包
Description 你是任意性复杂机器公司(Arbitrarily Complex Machines, ACM)的经理,公司使用更加先进的机械设备生产先进的机器.原来的那一台生产机器已经坏了,所以 ...
- 【BZOJ】3963: [WF2011]MachineWorks
[题意]给定n台在时间di可以买入的机器,pi买入,可在任意时间ri卖出,买入和卖出之间的持有时间每天产生gi金钱,任意时间至多持有一台机器.给定初始钱数c和总天数T,求最大收益.n<=10^5 ...
- Solution -「WF2011」「BZOJ #3963」MachineWorks
\(\mathcal{Description}\) Link. 给定你初始拥有的钱数 \(C\) 以及 \(N\) 台机器的属性,第 \(i\) 台有属性 \((d_i,p_i,r_i,g_i ...
- bzoj3963[WF2011]MachineWorks cdq分治+斜率优化dp
3963: [WF2011]MachineWorks Time Limit: 30 Sec Memory Limit: 256 MBSubmit: 270 Solved: 80[Submit][S ...
- BZOJ3963: [WF2011]MachineWorks 【CDQ+斜率优化DP】*
BZOJ3963: [WF2011]MachineWorks Description 你是任意性复杂机器公司(Arbitrarily Complex Machines, ACM)的经理,公司使用更加先 ...
- 【BZOJ3963】[WF2011]MachineWorks cdq分治+斜率优化
[BZOJ3963][WF2011]MachineWorks Description 你是任意性复杂机器公司(Arbitrarily Complex Machines, ACM)的经理,公司使用更加先 ...
- BZOJ 3963 HDU3842 [WF2011]MachineWorks cdq分治 斜率优化 dp
http://acm.hdu.edu.cn/showproblem.php?pid=3842 写的check函数里写的<但是应该是<=,调了一下午,我是个zz. 就是普通的斜率优化因为有两 ...
随机推荐
- 个人作业2——NBA 2k18案例分析
产品:篮球体育类游戏NBA 2k18 选择理由:这款游戏是<NBA 2k>的正统续作,自己和身边的朋友都对篮球比较感兴趣,经常看NBA,所以近几年的版本都有购买下载,加上游戏中人物动作比较 ...
- 学号:201621123032 《Java程序设计》第12周学习总结
1:本周学习总结 1.1:以你喜欢的方式(思维导图或其他)归纳总结多流与文件相关内容. 2:面向系统综合设计-图书馆管理系统或购物车 2.1: 简述如何使用流与文件改造你的系统.文件中数据的格式如何? ...
- Beta冲刺Day2
项目进展 李明皇 今天解决的进度 优化了信息详情页的布局:日期显示,添加举报按钮等 优化了程序的数据传递逻辑 明天安排 程序运行逻辑的完善 林翔 今天解决的进度 实现微信端消息发布的插入数据库 明天安 ...
- 解析与动作联动得SDN数据平面
一种解析与执行联动的SDN可编程数据平面 现有问题和目标 在传统协议处理方式中,各层的协议类型和组合方式固定,使得添加或修改协议很困难(因为需要修改网络设备的解析模式) 基于解析和执行联动结构的可编程 ...
- 使用Github pages+jekyll搭建自己的博客(windows版)
最近突发奇想,想试试GitHub pages来搭建博客.网上一搜一大堆,嗯...看来还是挺简单的...于是自己撸起袖子干...... 结果对于我这种GitHub注册过,git 没用过,ruby.jek ...
- 在360、UC等浏览器,img不加载原因
问题:图片在360浏览器不被加载,在UC浏览器强制不显示. 前言不多说,直接上图. 360浏览器显示情况: UC浏览器显示情况: 由以上两张截图可以看到,在360浏览器,banner图片处根本没有加载 ...
- linux下安装redis和phpredis扩展
一.安装redis 1.下载redis-3.2.3.tar.gz wget http://download.redis.io/releases/redis-3.2.3.tar.gz 2.解压redis ...
- python 判断变量是否是 None 的三种写法
代码中经常会有变量是否为None的判断,有三种主要的写法:第一种是`if x is None`:第二种是 `if not x:`:第三种是`if not x is None`(这句这样理解更清晰`if ...
- iot前台开发环境:前后台访问映射
一.前端映射- java代码 二.路由设置 -前台代码 三.访问应用
- 配置ssh无密钥登陆
ssh 无密码登录要使用公钥与私钥. linux下可以用用ssh-keygen生成公钥/私钥对,下面以CentOS为例. 有机器LxfN1(192.168.136.128),LxfN2(192.168 ...