# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
421952 | idk321 | 카니발 티켓 (IOI20_tickets) | C++17 | 900 ms | 71744 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "tickets.h"
#include <vector>
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll INF = 1000000000000000000LL;
long long find_maximum(int k, std::vector<std::vector<int>> x) {
int n = x.size();
int m = x[0].size();
vector<vector<int>> answer;
answer.resize(n, vector<int>(m, -1));
if (m == 1)
{
for (int i = 0; i < n; i++) answer[i][0] = 0;
allocate_tickets(answer);
vector<int> values(n);
for (int i = 0; i < n; i++)
{
values[i] = x[i][0];
}
sort(values.begin(), values.end());
ll res = 0;
int mid = (0 + n - 1) / 2;
for (int i = 0; i < n; i++)
{
res += abs(values[mid] - values[i]);
}
return res;
}
int big = 0;
for (int i = 0; i < n; i++)
{
for (int j = 0; j < m; j++) big = max(big, x[i][j]);
}
if (big <= 1)
{
int turn = 0;
vector<vector<vector<int>>> isAt(n, vector<vector<int>>(2));
for (int i = 0; i < n; i++)
{
for (int j = 0; j < m; j++)
{
isAt[i][x[i][j]].push_back(j);
}
}
int res = 0;
for (int a = 0; a < k; a++)
{
vector<array<int, 3>> byFreq;
for (int i = 0; i < n; i++) byFreq.push_back({isAt[i][0].size(), isAt[i][1].size(), i});
sort(byFreq.rbegin(), byFreq.rend());
int f0 = 0;
int f1 = 0;
for (int i = 0; i < n / 2; i++)
{
int node = byFreq[i][2];
if (!isAt[node][0].empty())
{
answer[node][isAt[node][0].back()] = a;
isAt[node][0].pop_back();
f0++;
} else
{
answer[node][isAt[node][1].back()] = a;
isAt[node][1].pop_back();
f1++;
}
}
for (int i = n / 2; i < n; i++)
{
int node = byFreq[i][2];
if (!isAt[node][1].empty())
{
answer[node][isAt[node][1].back()] = a;
isAt[node][1].pop_back();
f1++;
} else
{
answer[node][isAt[node][0].back()] = a;
isAt[node][0].pop_back();
f0++;
}
}
res += min(f1, f0);
}
allocate_tickets(answer);
return res;
}
if (k == 1)
{
array<int, 3> best = {-1, -1, -1};
ll res = 0;
vector<int> resOrder(n);
for (int a = 0; a < 2 * n; a++)
{
int ai = a / 2;
int val = x[a / 2].front();
if (a % 2 == 1) val = x[a / 2].back();
vector<int> order(n);
order[a / 2] = (a % 2);
ll cres = 0;
int bigger = 0;
bool bad = false;
int taken = 0;
vector<array<int, 2>> poss;
for (int i = 0; i < n; i++)
{
if (i == a / 2) continue;
if (val < x[i].front())
{
taken++;
cres += x[i].back() - val;
order[i] = 1;
} else
{
cres += val - x[i].front();
if (x[i].back() >= val)
{
poss.push_back({x[i].back() - val - (val - x[i].front()), i});
}
}
}
sort(poss.rbegin(), poss.rend());
for (int i = 0; i < poss.size() && taken < n / 2; i++)
{
order[poss[i][1]] = 1;
cres += poss[i][0];
if (taken == n / 2 - 1 || taken == n / 2)
{
if (cres > res)
{
res = cres;
resOrder = order;
}
}
}
}
for (int i = 0; i < n; i++)
{
if (resOrder[i])
{
answer[i][m - 1] = 0;
} else
{
answer[i][0] = 0;
}
}
allocate_tickets(answer);
return res;
}
return 1;
}
/*
3 4 3
1 0 1 1
0 1 0 0
0 0 1 1
*/
컴파일 시 표준 에러 (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... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |