[USACO4.2]工序安排Job Processing
两种想法:
- (样例是真的良心,卡掉了两种错误做法)洗完一件马上塞一件到最快的空闲烘干机去?X,因为最后一件洗完的衣服决定了第二问的答案,但它并不一定得到最优待遇——最快的烘干机。 给最后一件洗完的衣服配最快的烘干机就是答案?X,最后一件烘干的衣服并不一定是最后一件洗完的衣服 那么正解:对于从后往前的每一件衣服,为它像第一问一样准备一台当前最好的、能用的烘干机,给它烘干,然后记录这台烘干机在我们的规划中将烘干这件衣服,即在它需要烘干一件衣服的时间上加上自己最开始的时间
- 如果不交换更优,出来最晚的进最快的B机器(不同机器),离A结束最近的和最晚开始B的凑成一对
代码1:
#include<bits/stdc++.h>
using namespace std;
int n,m,a,b,t[10010],ans;
struct node{
int s,v;
bool operator <(const node & a)const
{ return s>a.s; }//小根堆
}x;
priority_queue<node>q;
int main()
{
scanf("%d%d%d",&n,&a,&b);
for(int i=1;i<=a;i++)
{
scanf("%d",&x.v);
x.s=x.v;
q.push(x);
}
for(int i=1;i<=n;i++)
{
x=q.top();
q.pop();
t[i]=x.s;// 第i个物品完成操作A 结束的时间
x.s+=x.v;// 等待
q.push(x);
}
while(!q.empty()) q.pop();
for(int i=b;i>=1;i--)
{
scanf("%d",&x.v);
x.s=x.v;
q.push(x);
}
for(int i=n;i>=1;i--)
{
x=q.top();
q.pop();
if(x.s+t[i]>ans)ans=x.s+t[i];
x.s+=x.v;
q.push(x);
}
printf("%d %d",t[n],ans);
return 0;
}
代码2:这里工件时间由f,g两部分组成,等待时间已经加入
#include<bits/stdc++.h>
using namespace std;
const int N=1e6;
int n,aa,bb,a[N],b[N],x[N],y[N],f[N],g[N],p,q,ans;
int main(){
scanf("%d%d%d",&n,&aa,&bb);
for(int i=1;i<=aa;i++) scanf("%d",&a[i]),x[i]=a[i];
for(int i=1;i<=bb;i++) scanf("%d",&b[i]),y[i]=b[i];
for(int i=1;i<=n;i++)
{
f[i]=g[i]=1e9;
for(int j=1;j<=aa;j++) if(x[j]<f[i]) p=j,f[i]=x[j];
for(int j=1;j<=bb;j++) if(y[j]<g[i]) q=j,g[i]=y[j];
x[p]+=a[p];
y[q]+=b[q];
}
for(int i=1;i<=n;i++) ans=max(ans,f[i]+g[n-i+1]);
printf("%d %d",f[n],ans);
return 0;
}
[USACO4.2]工序安排Job Processing的更多相关文章
- 洛谷P2751 [USACO4.2]工序安排Job Processing
P2751 [USACO4.2]工序安排Job Processing 18通过 78提交 题目提供者该用户不存在 标签 难度普及+/提高 提交 讨论 题解 最新讨论 暂时没有讨论 题目描述 一家工 ...
- 洛谷 P2751 [USACO4.2]工序安排Job Processing 解题报告
P2751 [USACO4.2]工序安排Job Processing 题目描述 一家工厂的流水线正在生产一种产品,这需要两种操作:操作A和操作B.每个操作只有一些机器能够完成. 上图显示了按照下述方式 ...
- 洛谷P2751 工序安排Job Processing
题目 任务调度贪心. 需要明确一点,任务调度贪心题,并不是简单地应用排序的贪心,而是动态的运用堆,使每次选择是都能保持局部最优,并更新状态使得下次更新答案可以取到正确的最小值. 这是A过程的解. 然后 ...
- 洛谷P2751[USACO]工序安排
题目传送门 怎么说呢,这个题目我刚开始随便乱搞了几下,交了个暴力代码上去居然还水了49分,数据确实有点弱啊,然后看到洛谷上那位大佬Redbag的题解瞬间就佩服的五体投地,那真的是简洁.易懂又高效.直接 ...
- USACO Section 4
前言 好久没更新这个系列了,最近闲的无聊写一下.有两题搜索懒得写了. P2737 [USACO4.1]麦香牛块Beef McNuggets https://www.luogu.com.cn/probl ...
- 易普优APS(高级计划排程)演绎饭局模型(通俗的告诉您ERP计划与APS计划的区别)
一天中午,老张突然回到家里对妻子说:“亲爱的老婆,晚上几个同事要来家里吃饭.这次我专门回家来要用最先进的ERP理念来完成咱家的请客过程了,要把这次宴会搞成一次ERP家宴.你看,我已经用CRM客户关系管 ...
- Java:并发笔记-01
Java:并发笔记-01 说明:这是看了 bilibili 上 黑马程序员 的课程 java并发编程 后做的笔记 1. 进程与线程 本章内容 进程和线程的概念 并行和并发的概念 线程基本应用 1.1 ...
- OLTP(on-line transaction processing)与OLAP(On-Line Analytical Processing)
OLTP与OLAP的介绍 数据处理大致可以分成两大类:联机事务处理OLTP(on-line transaction processing).联机分析处理OLAP(On-Line Analytical ...
- [翻译]MapReduce: Simplified Data Processing on Large Clusters
MapReduce: Simplified Data Processing on Large Clusters MapReduce:面向大型集群的简化数据处理 摘要 MapReduce既是一种编程模型 ...
随机推荐
- Nagios 请检查HTTP服务器关于该CGI的访问权限设置
无权查看任何主机的信息. 请检查HTTP服务器关于该CGI的访问权限设置. 搜索了一下方法 确保 htpasswd.user的所有组为nagios 解决办法: vi /usr/local/nagios ...
- [转]axios请求超时,设置重新请求的完美解决方法
自从使用Vue2之后,就使用官方推荐的axios的插件来调用API,在使用过程中,如果服务器或者网络不稳定掉包了, 你们该如何处理呢? 下面我给你们分享一下我的经历. 具体原因 最近公司在做一个项目, ...
- FIS 使用
从淘宝npm镜像安装fis $ npm install -g fis --registry=https://registry.npm.taobao.org 安装less插件 $ npm install ...
- WPF使用MVVM(二)-命令绑定
WPF使用MVVM(二)-命令绑定 上一节已经介绍了WPF的属性绑定,这使得我们只需要指定界面的DataContext,然后就可以让界面绑定我们的属性数据呢. 但是上一节还遗留了一个问题就是我们的按钮 ...
- TextBox,RichTextBox设置行高
/// <summary> /// 设置行距 /// </summary> /// <param name="ctl">控件</param ...
- Ajax_axios发送ajax请求
Ajax_axios发送ajax请求 这篇笔记主要讲一下axios基本的发送ajax请求的方法 axios在当前的前端行业里面是用的比较热门的一个 下面给大家分享一下它axios的一个基本用法 这段代 ...
- QT控件之QSlider
singleStep:比如按下键盘的左右建,每次移动的距离 pageStep:比如用鼠标对准滑动条的前面按下,每次移动的距离 value:初始默认值 接下来看该控件拥有的信号: 重点看后面的四个,看字 ...
- python3 requests的content和text方法
text返回的是Unicode型的数据 content返回的是是二进制的数据. 也就是说,如果你想取文本,可以通过r.text. 如果想取图片,文件,则可以通过r.content >>&g ...
- 不难懂------git开发过程中流程
001.创建仓库 002.新建项目 003.初始化仓库 这一步不需要做 git init : 文件夹中会多出一个隐藏的.git文件 004.克隆项目 git clone <项目地址> 0 ...
- Redis Hyperloglog的原理及数学理论的通俗理解
redis中有一种数据格式,hyperloglog,本文就此数据结构的作用.redis的实现及其背后的数学原理作一个整理.当然本文不包含任何数学公式,而是希望用直观的例子帮大家理解. 主要内容如下: ...