-
Notifications
You must be signed in to change notification settings - Fork 814
/
Copy path1014. Waiting in Line (30).cpp
61 lines (60 loc) · 1.79 KB
/
1014. Waiting in Line (30).cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
#include <iostream>
#include <queue>
#include <vector>
using namespace std;
struct node {
int poptime, endtime;
queue<int> q;
};
int main() {
int n, m, k, q, index = 1;
scanf("%d%d%d%d", &n, &m, &k, &q);
vector<int> time(k + 1), result(k + 1);
for(int i = 1; i <= k; i++) {
scanf("%d", &time[i]);
}
vector<node> window(n + 1);
vector<bool> sorry(k + 1, false);
for(int i = 1; i <= m; i++) {
for(int j = 1; j <= n; j++) {
if(index <= k) {
window[j].q.push(time[index]);
if(window[j].endtime >= 540)
sorry[index] = true;
window[j].endtime += time[index];
if(i == 1)
window[j].poptime = window[j].endtime;
result[index] = window[j].endtime;
index++;
}
}
}
while(index <= k) {
int tempmin = window[1].poptime, tempwindow = 1;
for(int i = 2; i <= n; i++) {
if(window[i].poptime < tempmin) {
tempwindow = i;
tempmin = window[i].poptime;
}
}
window[tempwindow].q.pop();
window[tempwindow].q.push(time[index]);
window[tempwindow].poptime += window[tempwindow].q.front();
if(window[tempwindow].endtime >= 540)
sorry[index] = true;
window[tempwindow].endtime += time[index];
result[index] = window[tempwindow].endtime;
index++;
}
for(int i = 1; i <= q; i++) {
int query, minute;
scanf("%d", &query);
minute = result[query];
if(sorry[query] == true) {
printf("Sorry\n");
} else {
printf("%02d:%02d\n",(minute + 480) / 60, (minute + 480) % 60);
}
}
return 0;
}