Submission #416740

#TimeUsernameProblemLanguageResultExecution timeMemory
416740winstonyinJob Scheduling (CEOI12_jobs)C++11
0 / 100
481 ms24096 KiB
#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 timeMemoryGrader output
Fetching results...