两种想法:

  1. (样例是真的良心,卡掉了两种错误做法)洗完一件马上塞一件到最快的空闲烘干机去?X,因为最后一件洗完的衣服决定了第二问的答案,但它并不一定得到最优待遇——最快的烘干机。   给最后一件洗完的衣服配最快的烘干机就是答案?X,最后一件烘干的衣服并不一定是最后一件洗完的衣服     那么正解:对于从后往前的每一件衣服,为它像第一问一样准备一台当前最好的、能用的烘干机,给它烘干,然后记录这台烘干机在我们的规划中将烘干这件衣服,即在它需要烘干一件衣服的时间上加上自己最开始的时间
  2. 如果不交换更优,出来最晚的进最快的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的更多相关文章

  1. 洛谷P2751 [USACO4.2]工序安排Job Processing

    P2751 [USACO4.2]工序安排Job Processing 18通过 78提交 题目提供者该用户不存在 标签 难度普及+/提高 提交  讨论  题解 最新讨论 暂时没有讨论 题目描述 一家工 ...

  2. 洛谷 P2751 [USACO4.2]工序安排Job Processing 解题报告

    P2751 [USACO4.2]工序安排Job Processing 题目描述 一家工厂的流水线正在生产一种产品,这需要两种操作:操作A和操作B.每个操作只有一些机器能够完成. 上图显示了按照下述方式 ...

  3. 洛谷P2751 工序安排Job Processing

    题目 任务调度贪心. 需要明确一点,任务调度贪心题,并不是简单地应用排序的贪心,而是动态的运用堆,使每次选择是都能保持局部最优,并更新状态使得下次更新答案可以取到正确的最小值. 这是A过程的解. 然后 ...

  4. 洛谷P2751[USACO]工序安排

    题目传送门 怎么说呢,这个题目我刚开始随便乱搞了几下,交了个暴力代码上去居然还水了49分,数据确实有点弱啊,然后看到洛谷上那位大佬Redbag的题解瞬间就佩服的五体投地,那真的是简洁.易懂又高效.直接 ...

  5. USACO Section 4

    前言 好久没更新这个系列了,最近闲的无聊写一下.有两题搜索懒得写了. P2737 [USACO4.1]麦香牛块Beef McNuggets https://www.luogu.com.cn/probl ...

  6. 易普优APS(高级计划排程)演绎饭局模型(通俗的告诉您ERP计划与APS计划的区别)

    一天中午,老张突然回到家里对妻子说:“亲爱的老婆,晚上几个同事要来家里吃饭.这次我专门回家来要用最先进的ERP理念来完成咱家的请客过程了,要把这次宴会搞成一次ERP家宴.你看,我已经用CRM客户关系管 ...

  7. Java:并发笔记-01

    Java:并发笔记-01 说明:这是看了 bilibili 上 黑马程序员 的课程 java并发编程 后做的笔记 1. 进程与线程 本章内容 进程和线程的概念 并行和并发的概念 线程基本应用 1.1 ...

  8. OLTP(on-line transaction processing)与OLAP(On-Line Analytical Processing)

    OLTP与OLAP的介绍 数据处理大致可以分成两大类:联机事务处理OLTP(on-line transaction processing).联机分析处理OLAP(On-Line Analytical ...

  9. [翻译]MapReduce: Simplified Data Processing on Large Clusters

    MapReduce: Simplified Data Processing on Large Clusters MapReduce:面向大型集群的简化数据处理 摘要 MapReduce既是一种编程模型 ...

随机推荐

  1. linux -安装mysql,配置密码,开启远程访问

    1.安装 下载yum源的安装包 yum install https://repo.mysql.com//mysql80-community-release-el7-1.noarch.rpm 安装 yu ...

  2. centos7 date时间命令

    date "+%F %T" %F     full date; same as %Y-%m-%d  --相当于年月日格式 %T     time; same as %H:%M:%S ...

  3. linux高大上命令001

        [ linux命令 sed ] sed是一个管道命令,可以分析standard input 而且sed可以将数据进行替换.删除.新增.选取的特定的功能 sed [-nefr] [动作] -n ...

  4. 关于jar包和war读取静态文件

    在war包中static中的静态文件,打成jar包后却读取不到,这是为什么呢,让我门看下两种读取的区别 一.war包中都取静态模板文件 public static void download(Stri ...

  5. 校招——面试(Android岗)总结

    PS:持续更新,未完待续 2016.8.24某为面试 自我介绍一下 链表和数组的区别 数组的存储空间是静态.连续分布的,初始化过大会造成空间浪费,过小会使空间溢出:链表的存储空间是动态分布的,只要内存 ...

  6. rocketmq实现延迟队列(精确到秒级)

    最近项目里需要在延时队列,但是开源版本rocketmq不支持任意时间延时,造成有些任务无法执行 参考了网上的不少文章,但是都么有实现,所以再开源的基础上改造了个支持任意时间延时的队列. 源码地址: h ...

  7. Allure测试报告完整学习笔记

    目录 简介 安装Allure Allure测试报告的结构 Java TestNG集成Allure Report Python Pytest集成Allure Report 简介 假如你想让测试报告变得漂 ...

  8. DBeaver下载安装与连接MySQL数据库

    一.Dbeaver下载 官网下载地址:Download | DBeaver Community 点击"Windows 64 bit (installer)"即可进行下载. 二.Db ...

  9. 3. scala-spark wordCount 案例

    1. 创建maven 工程 2. 相关依赖和插件 <dependencies> <dependency> <groupId>org.apache.spark< ...

  10. springboot 配置mybatis 配置mapper.xml

    # 插件 进行配置 也可以用yml # 1. 配置 Tomcat 修改端口号 server.port=8848 server.context-path=/zxf #2.配置数据源 spring.dat ...