# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
597421 | AryamanRtunjay | Job Scheduling (CEOI12_jobs) | C++17 | 150 ms | 31800 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.
#pragma GCC optimize("Ofast,unroll-loops")
#pragma GCC target("avx2,popcnt,lzcnt,abm,bmi,bmi2,fma")
#include <bits/stdc++.h>
using num = int64_t;
using namespace std;
#define rep(i, a, b) for(int i = a; i < (b); ++i)
#define REPI(t, n) for (num t = 0; t < n; ++t)
#define all(x) begin(x), end(x)
#define sz(x) (int)(x).size()
using ll = long long;
using pii = pair<int, int>;
using vi = vector<int>;
#ifdef TESTING
#define DEBUG(...) __VA_ARGS__
#else
#define DEBUG(...)
#endif
bool possible(vector<vector<num>> &jobs, num D, num M) {
num N = sz(jobs);
vector<num> jobsLeft(N);
num idx = 0;
REPI(i, N) {
if (idx+D < i) return false;
jobsLeft[i] = sz(jobs[i]);
num spent = 0;
while (spent < M) {
if (idx > i) break;
num canSpend = min(M-spent, jobsLeft[idx]);
jobsLeft[idx] -= canSpend;
spent += canSpend;
if (jobsLeft[idx] == 0) ++idx;
}
}
while ((idx < N) && (jobsLeft[idx] == 0)) ++idx;
return (idx == N);
}
int main() {
cin.tie(0)->sync_with_stdio(0);
cin.exceptions(cin.failbit);
num N, D, M;
cin >> N >> D >> M;
vector<vector<num>> jobs(N);
REPI(i, M) {
num x;
cin >> x;
--x;
jobs[x].push_back(i+1);
}
num lo = 1, hi = M;
while (lo < hi) {
num mid = (lo+hi) >> 1;
if (possible(jobs, D, mid)) hi = mid;
else lo = mid+1;
}
queue<num> jobsPending;
vector<vector<num>> ans(N);
REPI(i, N) {
for (num job : jobs[i]) jobsPending.push(job);
REPI(j, lo) {
if (jobsPending.empty()) break;
num curJob = jobsPending.front();
jobsPending.pop();
ans[i].push_back(curJob);
}
}
cout << lo << "\n";
REPI(i, N) {
for (num job : ans[i]) cout << job << " ";
cout << "0\n";
}
}
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |