# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
222916 | DodgeBallMan | 저울 (IOI15_scales) | C++14 | 6 ms | 512 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#include "scales.h"
#define pii pair<int, int>
#define x first
#define y second
using namespace std;
int ret[10], ans[10], coin[10];
vector<pii> all;
/*void answer( int a[] ) {
printf("ANS : ");
for( int i = 0 ; i < 6 ; i++ ) printf("%d ",a[i]);
printf("\n");
}
int getLightest( int a, int b, int c ) {
int p[3];
for( int i = 0 ; i < 6 ; i++ ) {
if( coin[i] == a ) p[0] = i;
else if( coin[i] == b ) p[1] = i;
else if( coin[i] == c ) p[2] = i;
}
sort( p, p+3 );
return coin[p[0]];
}
int getMedian( int a, int b, int c ) {
int p[3];
for( int i = 0 ; i < 6 ; i++ ) {
//printf("%d ",coin[i]);
if( coin[i] == a ) p[0] = i;
else if( coin[i] == b ) p[1] = i;
else if( coin[i] == c ) p[2] = i;
}
//printf("\n");
sort( p, p+3 );
//printf("%d %d %d %d %d %d\n",a,b,c,p[0],p[1],p[2]);
return coin[p[1]];
}
int getNextLightest( int a, int b, int c, int d ) {
int p[4], x, wow;
for( int i = 0 ; i < 6 ; i++ ) {
if( coin[i] == a ) p[0] = i;
else if( coin[i] == b ) p[1] = i;
else if( coin[i] == c ) p[2] = i;
else if( coin[i] == d ) p[3] = i, x = i;
}
sort( p, p+4 );
for( int i = 0 ; i < 4 ; i++ ) if( p[i] == x ) wow = i;
return coin[p[(wow+1)%4]];
}*/
void solve( int now ) {
int temp = getNextLightest( ans[0], ans[1], ans[2], ans[now] );
if( temp == ans[0] ) {
int temp2 = getLightest( ans[0], ans[1], ans[now] );
if( temp2 == ans[now] ) all.emplace_back( -1, now );
else all.emplace_back( 2, now );
}
else if( temp == ans[1] ) all.emplace_back( 0, now );
else all.emplace_back( 1, now );
}
void orderCoins() {
//for( int i = 0 ; i < 6 ; i++ ) printf("%d ",coin[i]);
//printf("\n");
memset( ret, 0, sizeof ret ), memset( ans, 0, sizeof ans ), all.clear();
ans[0] = getLightest( 1, 2, 3 );
ans[1] = getMedian( 1, 2, 3 );
ans[2] = 6 - ans[0] - ans[1];
ans[3] = getLightest( 4, 5, 6 );
ans[4] = getMedian( 4, 5, 6 );
ans[5] = 15 - ans[3] - ans[4];
//printf("ANS:");
//for( int i = 0 ; i < 6 ; i++ ) printf("%d ", ans[i]);
//printf("\n");
solve( 3 ), solve( 4 ), solve( 5 );
all.emplace_back( 0, 0 ), all.emplace_back( 1, 1 ), all.emplace_back( 2, 2 );
sort( all.begin(), all.end() );
for( int i = 0 ; i < 6 ; i++ ) ret[i] = ans[all[i].y];
answer( ret );
}
void init( int t ) {
for( int i = 1 ; i <= t ; i++ ) {
//for( int j = 0 ; j < 6 ; j++ ) { scanf("%d",&coin[j]); }
orderCoins();
}
}
/*int main()
{
int n;
scanf("%d",&n);
init( n );
}*/
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |