http://acm.hdu.edu.cn/showproblem.php?pid=3842 (题目链接)

题意

  一个公司使用一个厂房$D$天,希望获利最大。有$n$台机器,每一台可以在第$D_i$天购买,需要支付$P_i$,购买那天以后每一天可以获得$G_i$的收益,将它卖出可以获得$R_i$的收益,问到第$D+1$天的最大收益。

Solution

  直接对天数不好dp,因为$D_i$可能会有重复,我们对机器进行dp。将时间离散化后,给机器按照$D_i$并从小到大排好序后,$f[i]$表示第$i$台机器出售那天的最大获利,那么在这一天可以卖出这段时间正在使用的机器,或者是延续上一天的状态,转移:$$f[i]=max\{f[i-1],f[j]-P[j]+R[j]+G[j]*(D[i]-D[j]-1)\}$$

  条件是$f[j]>=P[j]$,所以:$$X[j]=G[j]$$

$$Y[j]=f[j]-P[j]+R[j]-G[j]*(D[j]+1)$$

$$K=-D[i]$$

  所以我们CDQ一下就好了。

细节

  多个机器的$D_i$相等,但是我们要把他们的处理顺序分开。多组数据注意清空。

代码

// hdu3842
#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<cmath>
#define LL long long
#define inf (1ll<<30)
#define Pi acos(-1.0)
#define free(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout)
using namespace std; const int maxn=200010;
int n,m,D,t[maxn],st[maxn],w[maxn];
LL f[maxn];
struct point {LL x,y,t;}p[maxn],np[maxn];
struct data {LL D,P,R,G,k,id;}q[maxn],nq[maxn]; bool cmp(data a,data b) {
return a.k<b.k;
}
double slope(point a,point b) {
return a.x==b.x ? inf*(b.y>a.y ? 1 : -1) : (double)(b.y-a.y)/(double)(b.x-a.x);
}
void solve(int l,int r) {
if (l==r) {
f[l]=max(f[l-1],f[l]);
p[l]=(point){q[l].G,f[l]-q[l].P+q[l].R-q[l].G*(q[l].D+1),f[l]>=q[l].P};
return;
}
int mid=(l+r)>>1,top=0,l1=l,l2=mid+1;
for (int i=l;i<=r;i++) q[i].id<=mid ? nq[l1++]=q[i] : nq[l2++]=q[i];
for (int i=l;i<=r;i++) q[i]=nq[i];
solve(l,mid);
for (int i=l;i<=mid;i++) if (p[i].t) {
while (top>1 && slope(p[st[top-1]],p[st[top]])<slope(p[st[top]],p[i])) top--;
st[++top]=i;
}
for (int i=mid+1;i<=r;i++) {
while (top>1 && slope(p[st[top-1]],p[st[top]])<q[i].k) top--;
int j=st[top];
f[q[i].id]=max(f[q[i].id],p[j].y-q[i].k*p[j].x);
}
solve(mid+1,r);
for (int i=l,j=mid+1,k=l;i<=mid || j<=r;) {
if (j>r || (i<=mid && p[i].x<p[j].x)) np[k++]=p[i++];
else np[k++]=p[j++];
}
for (int i=l;i<=r;i++) p[i]=np[i];
}
int main() {
int T=0;
while (scanf("%d%lld%d",&n,&f[0],&D)!=EOF) {
if (!n && !f[0] && !D) break;
for (int i=1;i<=n;i++) {
scanf("%lld%lld%lld%lld",&q[i].D,&q[i].P,&q[i].R,&q[i].G);
t[i]=q[i].D;q[i].k=-q[i].D;
}
t[++n]=++D;q[n]=(data){D,0,0,0,-D,n};
sort(t+1,t+1+n);m=unique(t+1,t+1+n)-t-1;
for (int i=1;i<=n;i++) q[i].id=lower_bound(t+1,t+1+m,q[i].D)-t;
for (int i=1;i<=n;i++) w[q[i].id]++;
for (int i=1;i<=n;i++) w[i]+=w[i-1];
for (int i=1;i<=n;i++) q[i].id=w[q[i].id]--;
for (int i=1;i<=n;i++) w[i]=0;
sort(q+1,q+1+n,cmp);
solve(1,n);
printf("Case %d: %lld\n",++T,f[n]);
memset(f,0,sizeof(f));
}
return 0;
}

【hdu3842】 Machine Works的更多相关文章

  1. 【Poj1325】Machine Schedule机器调度

    目录 List Description Input Output Sample Input Sample Output HINT Solution Code Position: http://poj. ...

  2. 【UVA1194】Machine Schedule

    题目大意:给定 N 个任务和两台机器,每个任务可以在任意一台机器上执行,每台机器有 N 个启动状态,不同任务需要机器在不同的状态下执行,求执行所有任务需要多少个不同的状态. 题解:由于一个任务一定要被 ...

  3. 【332】Machine Learning

    Reference: 决策树方法-对买电脑进行分类预测 Reference: 最邻近规则分类(K-Nearest Neighbor)KNN算法应用 Reference: python 内建函数 str ...

  4. 【hdu4045】Machine scheduling(dp+第二类斯特林数)

    传送门 题意: 从\(n\)个人中选\(r\)个出来,但每两个人的标号不能少于\(k\). 再将\(r\)个人分为不超过\(m\)个集合. 问有多少种方案. 思路: 直接\(dp\)预处理出从\(n\ ...

  5. 机器学习(Machine Learning)&深度学习(Deep Learning)资料【转】

    转自:机器学习(Machine Learning)&深度学习(Deep Learning)资料 <Brief History of Machine Learning> 介绍:这是一 ...

  6. 【机器学习实战】Machine Learning in Action 代码 视频 项目案例

    MachineLearning 欢迎任何人参与和完善:一个人可以走的很快,但是一群人却可以走的更远 Machine Learning in Action (机器学习实战) | ApacheCN(apa ...

  7. 【UML】-NO.43.EBook.5.UML.1.003-【UML 大战需求分析】- 状态机图(State Machine Diagram)

    1.0.0 Summary Tittle:[UML]-NO.43.EBook.1.UML.1.003-[UML 大战需求分析]- 状态机图(State Machine Diagram) Style:D ...

  8. 【翻译】What is State Machine Diagram(什么是状态机图)?

    [翻译]What is State Machine Diagram(什么是状态机图)? 写在前面 在上一篇学习类图的时候将这个网站上的类图的一篇文章翻译了出来,感觉受益良多,今天来学习UML状态机图, ...

  9. 【原】Coursera—Andrew Ng机器学习—Week 6 习题—Advice for applying machine learning

    [1] 诊断的作用 [2]过拟合 [3] [4] 高偏差bias,欠拟合underfitting 高方差variance,过拟合overfitting [5]参数λ Answer:  λ太大,则参数都 ...

随机推荐

  1. 20155327 李百乾 Exp7 网络欺诈防范

    20155327 李百乾 Exp7 网络欺诈防范 基础问题回答 (1)通常在什么场景下容易受到DNS spoof攻击 就此次试验来看,被收到NDSspoof攻击,首先要被攻击机扫描,并被设置为目标,所 ...

  2. linux下通过软连接实现访问项目路径外面的资源

            在javaweb项目开发中,图片上传是个比较常见的场景.一般都是在项目路径下建个文件夹,然后上传到该文件夹下:这样这个图片就可以和静态资源一样被直接访问.这样的好处就是访问这图片特别方 ...

  3. [2016北京集训试题15]cot-[分块]

    Description Solution 如图,假如我们知道了以任何一个点为顶点的135-180度的前缀和和90-180度的前缀和,我们就可以搞出三角形的面积. 差分.add[i][j]和dev[i] ...

  4. STEAM 自动安装时提示C++ 安装不了等问题

    [情况] 今天安装游戏, 安装时自动安装 Visual C++ 2015 x64 Minimum Runtime ....不成功, 提示网络源不可使用, 或者使用以下安装源 C:\ProgramDat ...

  5. Gitlab+Jenkins学习之路(十四)之自动化脚本部署实践

    目录 一.环境说明和准备 1.环境说明 2.服务器准备工作 二.发布脚本编写 1.自动化部署流程设计 2.自动化部署脚本编写 三.发布测试 1.开发机和github添加ssh信任 2.克隆项目到开发机 ...

  6. 本地navicat远程连接到云服务器数据库

    本来没有开启秘钥的远程服务器端数据库连接非常方便,就在新建连接上填入数据就ok了,但是开启SSH秘钥后的服务器连接有一个大坑,下面来详细讲讲. 其实开启了秘钥,在新建连接下,先选择SSH方式登录到远程 ...

  7. linux查找进程pid并杀掉

    命令:ps aux | grep `pwd` | grep -v  grep | awk '{print $2}' | xargs kill -9 详细解释[我的有道云笔记,不知道为什么没法直接复制到 ...

  8. JavaScript快速入门-ECMAScript运算符

    1.逻辑运算符 逻辑与:&&(and) 逻辑或:||(or) 逻辑非:!(not) 逻辑 AND 运算符(&&) 逻辑 AND 运算的运算数可以是任何类型的,不止是 B ...

  9. 设计模式 笔记 桥接模式 Bridge

    //---------------------------15/04/15---------------------------- //Bridge 桥接模式----对象结构型模式 /* 1:意图:将 ...

  10. 【分享】20个非常有用的Java程序片段

    福利来啦!!! 刚看到的一篇好东东,分享给大家,这些代码留着哦,以后会用得着的... 原文地址:http://developer.51cto.com/art/201306/398347.htm 1. ...