# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
1125741 | abel2008 | Job Scheduling (CEOI12_jobs) | C++20 | 1098 ms | 84780 KiB |
#include <iostream>
#include <set>
using namespace std;
int n,d,m,val;
multiset<int> requests;
bool solve(int crtd) {
multiset<int> req = requests,todo;
for (int i = 1;i<=n;++i) {
while(!req.empty()&&*req.begin()<=i) {
todo.insert(*req.begin());
req.erase(req.begin());
}
for (int j = 1;j<=crtd;++j) {
if (!todo.empty()) {
int num = *todo.begin();
todo.erase(todo.begin());
if (num+d<i) {
return 0;
}
}
}
}
if (!todo.empty())
return 0;
return 1;
}
int main() {
cin>>n>>d>>m;
for (int i = 1;i<=m;++i) {
cin>>val;
requests.insert(val);
}
int st = 1,dr = n;
while(st<dr) {
int mid = (st+dr)/2;
if (solve(mid)) {
dr = mid;
} else {
st = mid+1;
}
}
cout<<dr;
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |