# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
685289 | vxxwu | Job Scheduling (CEOI12_jobs) | C++17 | 598 ms | 42712 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <iostream>
#include <vector>
#include <algorithm>
#include <queue>
#include <set>
using namespace std;
#define MAXN 500
#define ll long long
#define int ll
#define max max<int>
#define min min<int>
#define f first
#define s second
typedef pair<int, int> pii;
int max_days, d, n;
vector<pii> jobs;
vector<vector<int>> sequence;
vector<vector<int>> secure;
bool check = true;
void work(int day, int index, int machines) {
// cout<<day<<" "<<index<<" "<<machines<<endl;
if(index>=n-1){
for(int i=day; i<=max_days; i++)
sequence.emplace_back();
return;
}
sequence.emplace_back();
if (jobs[index].f <= day) {
for (int i = index; i < min(index + machines, n); i++) {
// cout<<i<<endl;
if (jobs[i].f > day){
index=i;
break;
}
if (jobs[i].f >= day - d) {
sequence[sequence.size() - 1].emplace_back(jobs[i].s);
// cout<<"emplaced "<<jobs[i].f<<" "<<jobs[i].s<<endl;
} else if (jobs[i].f < day - d) {
check = false;
return;
}
if(i==min(index + machines, n)-1){
index=min(index + machines, n);
break;
}
}
}
work(day + 1, index, machines);
}
int32_t main() {
// freopen("test.in", "r", stdin);
cin >> max_days >> d >> n;
for (int i = 1; i <= n; i++) {
int a;
cin >> a;
jobs.emplace_back(a, i);
}
sort(begin(jobs), end(jobs));
// for(pii i:jobs) cout<<i.f<<endl;
int lower = 1, upper = n;
while (lower != upper) {
int mid = (lower + upper) / 2;
check = true;
sequence.clear();
// cout<<"try "<<mid<<endl;
work(1, 0, mid);
// cout<<mid<<endl;
if (check) {
upper = mid;
secure=sequence;
// cout<<"check"<<endl;
} else {
lower = mid + 1;
// cout<<"failed"<<endl;
}
}
cout << lower << endl;
for(vector<int> i:secure){
for(int j:i){
cout<<j<<" ";
}
cout<<0<<endl;
}
}
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |