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 "tickets.h"
#include <vector>
#include <bits/stdc++.h>
using namespace std;
#define vi vector<int>
#define lli long long int
#define pii pair<int, int>
#define rep(i, a, b) for(int i = (a); i <= (b); i++)
#define debugsl(x) cout << #x << " = " << x << ", "
#define debug(x) debugsl(x) << endl
#define MAX_N 1502
#define color first
#define pos second
#define maximo first
#define tipo second
#define chico 0
#define grande 1
lli suma;
int mediana, gr, ch, a, b;
vi todos;
vector<vector<int> > respuesta;
pii dp[MAX_N][MAX_N];
pii tickets[MAX_N][MAX_N];
int usados[MAX_N];
long long find_maximum(int k, vector<vector<int> > x) {
int n = x.size();
int m = x[0].size();
rep(i, 0, n - 1){
rep(j, 0, m - 1){
tickets[i][j] = {x[i][j], j};
todos.push_back(x[i][j]);
}
sort(tickets[i], tickets[i] + m);
}
sort(todos.begin(), todos.end());
mediana = todos[(n * m) >> 1];
dp[0][0] = {abs(tickets[0][m - 1].color - mediana), grande};
rep(i, 1, n - 1) dp[i][0] = {dp[i - 1][0].maximo + abs(tickets[i][m - 1].color - mediana), grande};
rep(i, 0, n - 1){
rep(j, 1, n / 2){
ch = dp[i - 1][j - 1].maximo + abs(tickets[i][0].color - mediana);
gr = dp[i - 1][j].maximo + abs(tickets[i][m - 1].color - mediana);
if (ch <= gr) dp[i][j] = {gr, grande};
else dp[i][j] = {ch, chico};
}
}
suma = dp[n - 1][n / 2].maximo;
a = n - 1;
b = n / 2;
while (a >= 0){
if (dp[a][b].tipo = grande) usados[a] = tickets[a][m - 1].pos;
else {
usados[a] = tickets[a][0].pos;
b--;
}
a--;
}
rep(i, 0, n - 1){
vector<int> bolsa(m);
rep(j, 0, m - 1){
if (j == usados[i]) bolsa[j] = 0;
else bolsa[j] = -1;
}
respuesta.push_back(bolsa);
}
allocate_tickets(respuesta);
return suma;
}
Compilation message (stderr)
tickets.cpp: In function 'long long int find_maximum(int, std::vector<std::vector<int> >)':
tickets.cpp:62:27: warning: suggest parentheses around assignment used as truth value [-Wparentheses]
62 | if (dp[a][b].tipo = grande) usados[a] = tickets[a][m - 1].pos;
| ^
# | 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... |