이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
//#pragma GCC target("avx2")
//#pragma GCC optimization("O3")
//#pragma GCC optimization("unroll-loops")
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define pii pair<int, int>
#define pll pair<ll, ll>
#define ff first
#define ss second
#define pb push_back
#define SZ(x) ((int)(x).size())
#define all(x) x.begin(), x.end()
#define rep(i, a, b) for(int i = (a); i < (b); i++)
#define per(i, a, b) for(int i = (a); i >= (b); i--)
mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());
void allocate_tickets(vector<vector<int>> _d);
struct Ticket{
ll val; int x, y;
bool operator<(const Ticket& oth) const{
return val < oth.val;
}
};
long long find_maximum(int K, vector<vector<int>> a){
int N = SZ(a), M = SZ(a[0]);
vector<int> l(N), r(N);
ll ans = 0;
vector<Ticket> ch;
rep(i, 0, N){
per(j, K - 1, 0){
ans -= a[i][j];
ch.pb({+a[i][j] + a[i][M+j-K], i, j});
}
l[i] = K - 1, r[i] = M;
}
sort(all(ch));
int cnt = K * N / 2;
while(cnt--){
auto [val, x, y] = ch.back();
ch.pop_back();
ans += val;
--l[x], --r[x];
}
vector<vector<int>> t(N, vector<int>(M, -1));
vector<int> p(N, M - 1);
rep(k, 0, K){
vector<pii> v1, v2;
rep(i, 0, N){
if(p[i] >= r[i]) v1.pb({a[i][p[i]], i});
if(l[i] >= 0) v2.pb({a[i][l[i]], i});
}
sort(all(v1));
sort(all(v2));
vector<bool> used(N, false);
int cnt = N / 2;
for(auto [n, i] : v1){
if(cnt && !used[i]){
used[i] = true;
t[i][p[i]--] = k;
--cnt;
}
}
for(auto [n, i] : v2){
if(!used[i]){
used[i] = true;
t[i][l[i]--] = k;
}
}
}
allocate_tickets(t);
return ans;
}
컴파일 시 표준 에러 (stderr) 메시지
tickets.cpp: In function 'long long int find_maximum(int, std::vector<std::vector<int> >)':
tickets.cpp:41:14: warning: structured bindings only available with '-std=c++17' or '-std=gnu++17'
41 | auto [val, x, y] = ch.back();
| ^
tickets.cpp:58:18: warning: structured bindings only available with '-std=c++17' or '-std=gnu++17'
58 | for(auto [n, i] : v1){
| ^
tickets.cpp:65:18: warning: structured bindings only available with '-std=c++17' or '-std=gnu++17'
65 | for(auto [n, i] : v2){
| ^
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |