Submission #1109732

#TimeUsernameProblemLanguageResultExecution timeMemory
1109732MrPavlitoJob Scheduling (CEOI12_jobs)C++17
0 / 100
200 ms21576 KiB
#include <bits/stdc++.h> #define pb push_back #define mp make_pair #define all(x) (x).begin(),(x).end() #define fi first #define sc second #define pii pair<int,int> using namespace std; const int MAXN = 2e5+5; const int mod7 = 1e9+7; const long long inf = 1e18; int n,d,m; vector<pii> niz; vector<pii> kopija; vector<pii> resenje; bool check(int mid) { kopija = niz; int cnt = 0; int trd = niz[0].fi; for(int i=0; i<m; i++) { if(cnt >= mid) { cnt = 0; trd++; } if(kopija[i].fi > trd) { trd = kopija[i].fi; cnt = 0; } else { cnt++; if(trd - kopija[i].fi > d)return false; } kopija[i].fi = trd; } resenje = kopija; return true; } signed main() { ios_base::sync_with_stdio(false),cin.tie(0), cout.tie(0); int tt=1; //cin >> tt; while(tt--) { cin >> n >> d >> m; niz.resize(m); for(int i=0; i<m; i++)cin >> niz[i].fi, niz[i].sc = i; sort(all(niz)); int l = 1; int r = m; int rez = m; while(l<=r) { int mid = l + r>>1; if(check(mid)) { r = mid-1; rez = mid; } else l = mid+1; } cout << rez << endl; sort(all(resenje)); } }

Compilation message (stderr)

jobs.cpp: In function 'int main()':
jobs.cpp:64:25: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
   64 |             int mid = l + r>>1;
      |                       ~~^~~
#Verdict Execution timeMemoryGrader output
Fetching results...