【题目链接】:http://codeforces.com/problemset/problem/452/D

【题意】



洗衣服有3个步骤,洗,干,叠;

有对应的3种洗衣机,分别有n1,n2,n3台,然后每一种洗衣机,一台完成对应的步骤所需的时间为t1,t2,t3;

已知你有k件衣服要洗;

问你最少需要洗多长时间;

【题解】



用3个优先队列;

维护每一种洗衣机,在何时是处于空闲状态的;(即什么时候会有一件衣服操作完);

每次将时间跳转到;

min{q1.top(),q2.top(),q3.top()};

然后将操作完的衣服放入下一步骤;

然后将正在等待操作的衣服;如果能放入对应的洗衣机,就放入;



【Number Of WA】



0



【完整代码】

#include <bits/stdc++.h>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define ms(x,y) memset(x,y,sizeof x)
#define Open() freopen("F:\\rush.txt","r",stdin)
#define Close() ios::sync_with_stdio(0),cin.tie(0) typedef pair<int,int> pii;
typedef pair<LL,LL> pll; const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};
const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};
const double pi = acos(-1.0);
const int N = 110;
const int INF = 0x3f3f3f3f; int k,n1,n2,n3,t1,t2,t3,ans;
int w1,w2,w3;
priority_queue <int,vector<int>,greater<int>> q1,q2,q3; int main(){
//Open();
Close();//scanf,puts,printf not use
//init??????
cin >> k >> n1 >> n2 >> n3 >> t1 >> t2 >> t3;
w1 = k;
q1.push(INF),q2.push(INF),q3.push(INF);
while (w1 || w2 || w3 || (int) q1.size()>1 || (int) q2.size()>1 || (int) q3.size()>1){
ans = min(q1.top(),min(q2.top(),q3.top()));
if (ans==INF) ans = 0;
while (q1.top()<=ans){
q1.pop();
w2++;
}
while (q2.top()<=ans){
q2.pop();
w3++;
}
while (q3.top()<=ans){
q3.pop();
}
while (w1 && (int) q1.size()<=n1){
w1--;
q1.push(ans+t1);
}
while (w2 && (int) q2.size()<=n2){
w2--;
q2.push(ans+t2);
}
while (w3 && (int) q3.size()<=n3){
w3--;
q3.push(ans+t3);
}
}
cout << ans << endl;
return 0;
}

最新文章

  1. Android Hack1 使用weight属性实现视图的居中显示
  2. [Linux主机] 优化你的php-fpm(php5.3+)让你的网站跑得更快
  3. audition输出参数设置
  4. ASP.NET 大文件上传的简单处理
  5. pushState onpopstate
  6. XE5 Android 开发数据访问手机端 解决乱码的办法
  7. SignalTap II逻辑分析仪的使用
  8. MFC error C2065: “IDD_DIALOG1” : 未声明的标识符 转载
  9. 黄源河《左偏树的应用》——数字序列(Baltic 2004)
  10. css——基础样式总结
  11. php版本的选择
  12. spark-shell报错:Exception in thread &quot;main&quot; java.lang.NoClassDefFoundError: org/apache/hadoop/fs/FSDataInputStream
  13. Spring整合DWR comet 实现无刷新 多人聊天室
  14. cannot update the cursor rep,since it is read-only
  15. Django-CRM项目学习(二)-模仿admin实现stark
  16. Eclipse:报错Failed to read artifact descriptor for org.springframework.boot:spring-boot-autoconfigure:jar:2.1.2.
  17. 第七章 鼠标(CHECKER1)
  18. 启动总是提示:Process finished with exit code 0
  19. psycopg事务
  20. codeforces水题100道 第十三题 Codeforces Round #166 (Div. 2) A. Beautiful Year (brute force)

热门文章

  1. ContextLoaderListener的说明
  2. zookeeper核心概念
  3. BZOJ 3674 可持久化并查集加强版(路径压缩版本)
  4. Oracle的JDBC Url的几种方式
  5. HDU 3886
  6. JS 推断URL中是否含有 http:// 假设没有则自己主动为URL加上
  7. [GraphQL] Mutations and Input Types
  8. Windows环境下msysgit安装git flow
  9. java基础——transient
  10. 2015.05.12,外语,读书笔记-《Word Power Made Easy》 15 “如何谈论不同人的特点” SESSION 45