[HNOI2001] 产品加工
题目类型:\(DP\)
传送门:>Here<
题意:有\(N\)个零件,每个零件有三种选择,在\(A\)机器加工,在\(B\)机器加工,同时在\(AB\)加工。其中所需要的时间分别为\(t1[i],t2[i],t3[i]\)。同一时刻一个机器只能加工一个零件。问加工完所有零件的最少时间
解题思路
考虑到有两个进程,以为\(dp\)会需要\(3\)维,然而……
令\(dp[i][j]\)表示前\(i\)个物品加工完毕,其中\(A\)机器用时\(j\)时,\(B\)机器的最小用时。于是每个物品有三种选择,分别转移即可。方程很简单。
但是这样的做法我们是按照\(1,2,...,N\)这样的顺序来加工物品的。那么转移的时候显然可能\(dp[i][j]\)不是在\(j\)的时候发生的,那对于第三种转移不就不合法了吗?
这里给出一个解释,不知道有没有其他解释方法:我们可以考虑先做所有并行的零件,然后再单独去做。这样的话只能更优不会不优(压掉了空余空间)
反思
难就难在\(d[i][j]\)的意义如何去定。其实这还是按照一个确定,一个不确定的思想来定的。当\(j\)定下来时,影响答案的只有\(B\)的时间了。我们只要保证\(j\)尽量小就好了。
Code
由于二维会被卡\(MLE\),因此滚动数组优化。但注意所有\(dp[j]\)不一定都从自身转移过来,因此要重新赋值。但又存在从自己转移过来的可能,所以特殊处理一下。
/*By DennyQi 2018*/
#include <cstdio>
#include <queue>
#include <cstring>
#include <algorithm>
using namespace std;
typedef long long ll;
const int MAXN = 6010;
const int INF = 1061109567;
inline int Max(const int a, const int b){ return (a > b) ? a : b; }
inline int Min(const int a, const int b){ return (a < b) ? a : b; }
inline int read(){
int x = 0; int w = 1; register char c = getchar();
for(; c ^ '-' && (c < '0' || c > '9'); c = getchar());
if(c == '-') w = -1, c = getchar();
for(; c >= '0' && c <= '9'; c = getchar()) x = (x<<3) + (x<<1) + c - '0'; return x * w;
}
int N,tot_a,tmp;
int t[4][MAXN],dp[5*MAXN];
int main(){
// freopen(".in","r",stdin);
N = read();
for(int i = 1; i <= N; ++i){
for(int j = 1; j <= 3; ++j){
t[j][i] = read();
}
}
memset(dp, 0x3f, sizeof dp);
if(t[2][1]){
dp[0] = t[2][1];
}
if(t[1][1]){
dp[t[1][1]] = 0;
}
if(t[3][1]){
dp[t[3][1]] = Min(dp[t[3][1]], t[3][1]);
}
tot_a = Max(t[1][1], t[3][1]);
for(int i = 2; i <= N; ++i){
tot_a += Max(t[1][i], t[3][i]);
for(int j = tot_a; j >= 0; --j){
int tmp = dp[j];
dp[j] = INF;
if(t[2][i]){
dp[j] = Min(dp[j], tmp + t[2][i]);
}
if(t[1][i] && j-t[1][i]>=0){
dp[j] = Min(dp[j], dp[j-t[1][i]]);
}
if(t[3][i] && j-t[3][i]>=0){
dp[j] = Min(dp[j], dp[j-t[3][i]] + t[3][i]);
}
// printf("dp[%d][%d] = %d\n",i,j,dp[j]);
}
}
int Ans(INF);
for(int i = 0; i <= tot_a; ++i){
Ans = Min(Ans, Max(i, dp[i]));
}
printf("%d", Ans);
return 0;
}
[HNOI2001] 产品加工的更多相关文章
- bzoj 1222: [HNOI2001]产品加工 dp
1222: [HNOI2001]产品加工 Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 381 Solved: 218[Submit][Status ...
- Bzoj 1222: [HNOI2001]产品加工 动态规划
1222: [HNOI2001]产品加工 Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 486 Solved: 298[Submit][Status ...
- 洛谷 P2224 [HNOI2001]产品加工 解题报告
P2224 [HNOI2001]产品加工 题目描述 某加工厂有A.B两台机器,来加工的产品可以由其中任何一台机器完成,或者两台机器共同完成.由于受到机器性能和产品特性的限制,不同的机器加工同一产品所需 ...
- 【BZOJ1222】[HNOI2001]产品加工 DP
[BZOJ1222][HNOI2001]产品加工 Description 某加工厂有A.B两台机器,来加工的产品可以由其中任何一台机器完成,或者两台机器共同完成.由于受到机器性能和产品特性的限制,不同 ...
- BZOJ1222[HNOI2001]产品加工——DP
题目描述 某加工厂有A.B两台机器,来加工的产品可以由其中任何一台机器完成,或者两台机器共同完成.由于受到机器性能和产品特性的限制,不同的机器加工同一产品所需的时间会不同,若同时由两台机器共同进行加工 ...
- 洛谷P2224 [HNOI2001] 产品加工 [DP补完计划,背包]
题目传送门 产品加工 题目描述 某加工厂有A.B两台机器,来加工的产品可以由其中任何一台机器完成,或者两台机器共同完成.由于受到机器性能和产品特性的限制,不同的机器加工同一产品所需的时间会不同,若同时 ...
- 【bzoj1222】[HNOI2001]产品加工 背包dp
题目描述 某加工厂有A.B两台机器,来加工的产品可以由其中任何一台机器完成,或者两台机器共同完成.由于受到机器性能和产品特性的限制,不同的机器加工同一产品所需的时间会不同,若同时由两台机器共同进行加工 ...
- 【BZOJ 1222】 [HNOI2001] 产品加工(DP)
Description 某加工厂有A.B两台机器,来加工的产品可以由其中任何一台机器完成,或者两台机器共同完成.由于受到机器性能和产品特性的限制,不同的机器加工同一产品所需的时间会不同,若同时由两台机 ...
- BZOJ1222: [HNOI2001]产品加工(诡异背包dp)
Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 907 Solved: 587[Submit][Status][Discuss] Descriptio ...
- bzoj1222: [HNOI2001]产品加工--DP
DP神题orz dp[i]表示机器1工作i小时,机器2工作dp[i]小时 那么对于每个任务: 选1:dp[i]=dp[i-a]; 选2:dp[i]=dp[i]+b; 选1+2:dp[i]=dp[i-c ...
随机推荐
- ABAP案例:灵活读取SAP各表的数据
案例说明 RFC读取表中数据. Import 参数名称 Type spec. 参考打印 FIELDS_NAME1 TYPE CHAR25 TABLE_NAME1 TYPE CHAR25 WHE ...
- Java开发笔记(八十六)通过缓冲区读写文件
前面介绍了利用文件写入器和文件读取器来读写文件,因为FileWriter与FileReader读写的数据以字符为单位,所以这种读写文件的方式被称作“字符流I/O”,其中字母I代表输入Input,字母O ...
- 杂牌机搞机之旅(二)————移植TWRP第三方Recovery并刷入
原本想把杂牌机作为android破解和开发的测试机,破解的话肯定是安装框架的嘛,毕竟有些是要涉及到脱壳 . 但是,我尝试安装xposed的时候,手机卡在了开机界面,也就是magisk出现了错误,如果想 ...
- 解析高德地图api获取省市区,生成最新三级联动sql表
前言: 最近项目中用到了全国省市区三级信息,但是网上找到的信息都是比较旧的信息.与现在最新的地区信息匹配不上.后来想到高德地图上可能有这些信息.所以解析了一下api接口,生成了相关省市区的sql信息. ...
- Spring+MyBatis整合过程
步骤: 1.引入Spring+MyBatis开发包 >spring(ioc aop dao)开发包 >mybatis开发包,dbcp,驱动包 >mybatis-spring.jar整 ...
- java 线程池 ---- newCachedThreadPool()
class MyThread implements Runnable{ private int index; public MyThread(int index){ this.index = inde ...
- ElasticSearch、Logstash、Kibana 搭建高效率日志管理系统
ELK (ElasticSearch.LogStash以及Kibana)三者组合是一个非常强大的工具,这里我们来实现监控日志文件并且收到日志到ElasticSearch搜索引擎,利用Kibana可视化 ...
- 从零学习Fluter(八):Flutter的四种运行模式--Debug、Release、Profile和test以及命名规范
从零学习Fluter(八):Flutter的四种运行模式--Debug.Release.Profile和test以及命名规范 好几天没有跟新我的这个系列文章,一是因为这两天我又在之前的基础上,重新认识 ...
- android中使用afinal一行源码显示网络图片
下面代码是关于android中使用afinal一行显示网络图片的代码. public class DemoActivity extends FinalActivity { @Override publ ...
- Vue components Cannot read property '__ob__' of undefined
在Vue开发过程中,子组件向父组件传值的过程中,函数时可以对应的触发的,但是当父组件要改变自己的属性的时候报错了. 具体的页面逻辑是这样的,父组件 子组件 点击了之后没有问题,子组件向父组件传值 t ...