| # | Time | Username | Problem | Language | Result | Execution time | Memory |
|---|---|---|---|---|---|---|---|
| 121728 | nvmdava | Teams (IOI15_teams) | C++17 | 4022 ms | 19600 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "teams.h"
#include <bits/stdc++.h>
using namespace std;
vector<pair<int, int> > ls;
void init(int N, int A[], int B[]) {
for(int i = 0; i < N; i++){
ls.push_back({A[i], B[i]});
}
sort(ls.begin(), ls.end(), [](pair<int, int>& lhs, pair<int, int>& rhs){
if(lhs.second == rhs.second)
return lhs.first > rhs.first;
return lhs.second > rhs.second;
});
}
int can(int M, int K[]) {
sort(K + 0, K + M, [](int& lhs ,int &rhs){
return lhs > rhs;
});
int it = 0;
priority_queue<int> pq;
for(int i = 0; i < M; i++){
while(it != ls.size() && ls[it].second >= K[i]){
pq.push(ls[it++].first);
}
while(!pq.empty() && pq.top() > K[i]) pq.pop();
while(K[i]--){
if(pq.empty()) return 0;
pq.pop();
}
}
return 1;
}Compilation message (stderr)
| # | Verdict | Execution time | Memory | Grader output |
|---|---|---|---|---|
| Fetching results... | ||||
| # | Verdict | Execution time | Memory | Grader output |
|---|---|---|---|---|
| Fetching results... | ||||
| # | Verdict | Execution time | Memory | Grader output |
|---|---|---|---|---|
| Fetching results... | ||||
| # | Verdict | Execution time | Memory | Grader output |
|---|---|---|---|---|
| Fetching results... | ||||
