이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "tickets.h"
#include <bits/stdc++.h>
using namespace std;
struct Item{
int x, i, j;
bool operator < (const Item &sc) const{
return x < sc.x;
}
};
long long find_maximum(int k, vector<vector<int>> arr){
int n = arr.size();
int m = arr[0].size();
vector ans(n, vector(m, -1));
long long ansvalue = 0;
vector<Item> v;
for(int i = 0; i < n; i++){
for(int j = 0; j < k; j++){
ansvalue += arr[i][m - 1 - j];
}
}
for(int i = 0; i < n; i++){
for(int j = 0; j < k; j++){
v.push_back({arr[i][j] + arr[i][m - k + j], i, j});
}
}
sort(v.begin(), v.end());
vector cnt(n, 0);
for(int i = 0; i < (n * k) / 2; i++){
ansvalue -= v[i].x;
arr[v[i].i][v[i].j] = cnt[v[i].i];
}
for(int i = (n * k) / 2; i < n * k; i++){
arr[v[i].i][m - k + v[i].j] = cnt[v[i].i];
}
allocate_tickets(ans);
return ansvalue;
}
# | 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... |