Submission #426960

#TimeUsernameProblemLanguageResultExecution timeMemory
426960arayiRobots (IOI13_robots)C++17
76 / 100
173 ms65540 KiB
#include "robots.h" #include <bits/stdc++.h> #define MP make_pair #define sc second #define ad push_back #define fr first using namespace std; const int N = 2e6 + 30; long long n, m, t; long long x[N], y[N], w[N], s[N], col[N], sm[N]; pair<long long, long long> a[N], b[N]; vector<long long> g[N]; bool stg(long long k) { for (long long i = 0; i <= m + 1; i++) sm[i] = 0; priority_queue <long long> q; long long i1 = 0; for (long long i = n; i >= 0; i--) { for(auto p : g[i]) q.push(-col[p]); while(q.size() > i1) sm[-q.top()]++, q.pop(); i1+=k; } i1 = 0; for (long long i = m; i >= 0; i--) { sm[i] += sm[i+1]; if(sm[i] > i1) return 0; i1+=k; } return 1; } int putaway(int A, int B, int T, int X[], int Y[], int W[], int S[]) { n=A, m=B, t=T; for (long long i = 0; i < T; i++) { w[i]=W[i]; s[i]=S[i]; a[i]=MP(w[i], i); b[i]=MP(s[i], i); } sort(a, a+t); sort(b, b+t); for (long long i = 0; i < n; i++) x[i] = X[i]; for (long long i = 0; i < m; i++) y[i] = Y[i]; sort(x,x+n); sort(y,y+m); long long i1 = n; for (long long i = t - 1; i >= 0; i--) { while(i1 && x[i1-1] > a[i].fr) i1--; g[i1].ad(a[i].sc); } i1 = m; for (long long i = t - 1; i >= 0; i--) { while (i1 && y[i1-1] > b[i].fr) i1--; col[b[i].sc] = i1; } long long l = 1, r = t + 1, ans = t + 10; while(l <= r) { long long mid = (l + r) / 2; if(stg(mid)) ans = mid, r = mid - 1; else l = mid + 1; } if(ans == t+10) return -1; return ans; }

Compilation message (stderr)

robots.cpp: In function 'bool stg(long long int)':
robots.cpp:22:24: warning: comparison of integer expressions of different signedness: 'std::priority_queue<long long int>::size_type' {aka 'long unsigned int'} and 'long long int' [-Wsign-compare]
   22 |         while(q.size() > i1) sm[-q.top()]++, q.pop();
      |               ~~~~~~~~~^~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...