# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
416740 | winstonyin | Job Scheduling (CEOI12_jobs) | C++11 | 481 ms | 24096 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <string>
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <algorithm>
#include <vector>
#include <cmath>
#include <array>
#include <map>
#include <set>
#include <fstream>
#include <unordered_map>
#include <queue>
using namespace std;
using pi = pair<int, int>;
using pd = pair<double, double>;
#define ll long long
#define all(x) (x).begin(), (x).end()
ll days, delay, requests;
vector<pair<ll,ll>> seq;
bool works(ll machines) {
if(days*machines < requests) {
return false;
}
ll cur_day = 0; ll cur_req = 0;
while(cur_day < days && cur_req < requests) {
for(ll j = 0; j < machines; j++) {
if(cur_req == requests) {
break;
}
if(seq[cur_req].first <= cur_day+1) {
if(cur_day+1 - seq[cur_req].first <= delay) {
cur_req++;
}
else {
return false;
}
}
else {
break;
}
}
cur_day++;
}
return cur_req == requests;
}
bool p_works(ll machines) {
if(days*machines < requests) {
return false;
}
ll cur_day = 0; ll cur_req = 0;
while(cur_day < days && cur_req < requests) {
for(ll j = 0; j < machines; j++) {
if(cur_req == requests) {
break;
}
if(seq[cur_req].first <= cur_day+1) {
if(cur_day+1 - seq[cur_req].first <= delay) {
cout << seq[cur_req].second << " ";
cur_req++;
}
else {
return false;
}
}
else {
break;
}
}
cout << 0 << endl;
cur_day++;
}
return cur_req == requests;
}
int main() {
cin >> days >> delay >> requests;
for(ll i = 0; i < requests; i++) {
ll day; cin >> day;
seq.push_back({day, i+1});
}
sort(all(seq));
ll a = 1, b = 1e9;
ll ans;
while(a <= b) {
ll mid = (a+b)/2;
// cout << a << " " << b << endl;
if(works(mid)) {
ans = mid;
b = mid-1;
}
else {
a = mid+1;
}
}
p_works(ans);
cout << ans;
}
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |