[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既是一种编程模型 ...
随机推荐
- redis的使用场景和优缺点
使用场景和优缺点: 2 Redis用来做什么? 通常局限点来说,Redis也以消息队列的形式存在,作为内嵌的List存在,满足实时的高并发需求.而通常在一个电商类型的数据处理过程之中,有关商品,热销, ...
- 【Java常用类】SimpleDateFormat
文章目录 SimpleDateFormat 默认构造器实例化对象 默认构造器的格式化 带参构造器实例化对象 带参构造器的格式化 自定义格式 解析 SimpleDateFormat 默认构造器实例化对象 ...
- OSI/RM体系结构
OSI/RM体系结构是第一个标准化的计算机网络体系结构. 它是针对广域网通信(也就是不同网络之间的通信)进行设计 的,将整个网络通信的功能划分为七个层次,由低到高分别是物理层(Physical L ...
- 扒一扒@Retryable注解,很优雅,有点意思!
你好呀,我是歪歪. 前几天我 Review 代码的时候发现项目里面有一坨逻辑写的非常的不好,一眼望去简直就是丑陋之极. 我都不知道为什么会有这样的代码存在项目里面,于是我看了一眼提交记录准备叫对应的同 ...
- 《剑指offer》面试题26. 树的子结构
问题描述 输入两棵二叉树A和B,判断B是不是A的子结构.(约定空树不是任意一个树的子结构) B是A的子结构, 即 A中有出现和B相同的结构和节点值. 例如: 给定的树 A: 3 / ...
- NPOI导出例子
public static string ExportAOrder(ExportData data) { var cellHeard = new Dictionary<string, strin ...
- linux + opencv + cuvid中使用cv::cuda::GpuMat类的一些坑
1.我最终成功实现了opencv中利用cuvid实现GPU视频解码:核心代码是: 1 cv::cuda::GpuMat d_frame; 2 cv::Ptr<cv::cudacodec::Vid ...
- 遇到奇怪的问题:web.py 0.40中使用web.input(),出现一堆奇怪的错误
有的请求很正常,有的请求就出现了500错误. 这里使用POST请求,然后在web.input()中出现了很长很长的错误. 猜测是这个机器上安装了python2.7 / python 3.6 / pyt ...
- Cesium入门13 - Extras - 附加内容
Cesium入门13 - Extras - 附加内容 Cesium中文网:http://cesiumcn.org/ | 国内快速访问:http://cesium.coinidea.com/ 剩下的代码 ...
- SSM项目使用拦截器实现登录验证功能
SSM项目使用拦截器实现登录验证功能 登录接口实现 public User queryUser(String UserName, String Password,HttpServletRequest ...