제출 #1204729

#제출 시각아이디문제언어결과실행 시간메모리
1204729nathlol2Job Scheduling (CEOI12_jobs)C++20
55 / 100
170 ms20288 KiB
#include <bits/stdc++.h> #define fi first #define sc second using namespace std; int n, d, m; pair<int, int> a[1000000]; bool ok(int x){ int now = 1; for(int i = 0;i<m / x;i++){ int t = (i + 1) * x; for(int j = i * x;j<t;j++){ if(a[j].fi + d < now){ return false; } } now++; } for(int i = (m / x) * x;i<m;i++){ if(a[i].fi + d < now){ return false; } } return true; } int main(){ ios_base::sync_with_stdio(false); cin.tie(NULL); cin >> n >> d >> m; for(int i = 0;i<m;i++){ cin >> a[i].fi; a[i].sc = i + 1; } sort(a, a + m); int l = 1, r = m, ans = -1; while(l <= r){ int mid = (l + r) / 2; if(ok(mid)){ ans = mid; r = mid - 1; }else{ l = mid + 1; } } vector<vector<int>> g(n + 1); int now = 1; int x = ans; for(int i = 0;i<m / x;i++){ int t = (i + 1) * x; for(int j = i * x;j<t;j++){ g[now].push_back(a[j].sc); } now++; } for(int i = (m / x) * x;i<m;i++){ g[now].push_back(a[i].sc); } cout << ans << '\n'; for(int i = 1;i<=n;i++){ for(auto x : g[i]){ cout << x << ' '; } cout << 0 << '\n'; } }
#Verdict Execution timeMemoryGrader output
Fetching results...