# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
345987 | emaborevkovic | 저울 (IOI15_scales) | C++14 | 0 ms | 0 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#include "scales.h"
using namespace std;
#define ll long long
#define ss second
#define ff first
#define mp make_pair
#define pb push_back
int res[6];
void answer(vector <int> w) {
}
void orderCoins() {
int a1, a2, a3, a4, a5, a6; // a1 < a2 < a3 && a4 < a5 < a6
a1 = getLightest(1, 2, 3);
a2 = getMedian(1, 2, 3);
if (a1 != 1 && a2 != 1) a3 = 1;
if (a1 != 2 && a2 != 2) a3 = 2;
if (a1 != 3 && a2 != 3) a3 = 3;
a4 = getLightest(4, 5, 6);
a5 = getMedian(4, 5, 6);
if (a4 != 4 && a5 != 4) a3 = 4;
if (a4 != 5 && a5 != 5) a3 = 5;
if (a4 != 6 && a5 != 6) a3 = 6; // do sad smo iskoristili 4 upita
int x = getNextLigtest(a4, a5, a3, a2);
if (x == a4) {
int srednji = getMedian(a5, a3, a6);
res[0] = a1; res[1] = a2; res[2] = a4;
if (srednji == a5) {
res[3] = a3;
res[5] = a6;
}
else if (srednji == a3) {
res[3] = a5;
res[5] = a6;
}
else {
res[3] = a5;
res[5] = a3;
}
res[4] = srednji;
}
else if (x == a3) {
int manji = getLightest(a1, a4, a2);
if (manji == a1) {
res[0] = a1;
res[1] = a4;
}
else {
res[0] = a4;
res[1] = a1;
}
res[2] = a2;
res[3] = a5;
int veci = getHeaviest(a3, a6, a1);
if (veci == a3) {
res[5] = a3;
res[4] = a6;
}
else {
res[4] = a3;
res[5] = a6;
}
}
else {
int next1 = getNextLightest(a4, a5, a2, a1);
if (next1 == a4) {
res[0] = a1;
res[1] = a4;
res[2] = a5;
int next2 = getNextLightest(a2, a3, a1, a6);
if (next2 == a2) {
res[3] = a6;
res[4] = a2;
res[5] = a3;
}
else if (next2 == a3) {
res[3] = a2;
res[4] = a6;
res[5] = a3;
}
else {
res[3] = a2;
res[4] = a3;
res[5] = a6;
}
}
else if (next1 == a5) {
res[0] = a4;
res[1] = a1;
res[2] = a5;
int next2 = getNextLightest(a2, a3, a1, a6);
if (next2 == a2) {
res[3] = a6;
res[4] = a2;
res[5] = a3;
}
else if (next2 == a3) {
res[3] = a2;
res[4] = a6;
res[5] = a3;
}
else {
res[3] = a2;
res[4] = a3;
res[5] = a6;
}
}
else {
res[0] = a4;
res[1] = a5;
int next2 = getNextLightest(a1, a2, a3, a6);
if (next2 == a2) {
res[2] = a1;
res[3] = a6;
res[4] = a2;
res[5] = a3;
}
else if (next2 == a3) {
res[2] = a1;
res[3] = a2;
res[4] = a6;
res[5] = a3;
}
else {
int najmanji = getLightest(a1, a6, a2);
if (najmanji == a6) {
res[2] = a6;
res[3] = a1;
res[4] = a2;
res[5] = a3;
}
else {
res[2] = a1;
res[3] = a2;
res[4] = a3;
res[5] = a6;
}
}
}
}
vector <int> sol;
for (int i=0;i<6;i++) sol.pb(res[i]);
answer(sol);
return;
}
void init(int t) {
while(t--) orderCoins();
}
/*
int main() {
ios_base::sync_with_stdio(false);
cin.tie(NULL);
vector <int> v = {1, 2, 5};
cout << delivery(3, 2, 8, v);
return 0;
}
*/