제출 #1310828

#제출 시각아이디문제언어결과실행 시간메모리
1310828dimitri.shengelia동굴 (IOI13_cave)C++20
0 / 100
62 ms556 KiB
#include <bits/stdc++.h> #include "cave.h" using namespace std; int tryCombination ( int S[] ); void answer( int S[], int D[] ); void exploreCave( int n ) { int a[n], b[n]; fill ( a, a + n, 0 ); fill ( b, b + n, -1 ); vector <int> v; int k; int l, r, z; for ( int i = 0; i < n; i++ ) { v.push_back( i ); } for ( int i = 0; i < n; i++ ) { for ( auto x : v ) { a[x] = 0; } k = tryCombination( a ); if ( k == -1 or k > i ) { k = 0; } else { k = 1; } l = 0, r = v.size(); while ( l <= r ) { int m = ( l + r ) / 2; for ( int j = m; j < (int)v.size(); j++ ) { a[v[j]] = 1 - k; } int k1 = tryCombination( a ); if ( k1 == -1 or k1 > i ) { r = m - 1; z = m - 1; } else { l = m + 1; } } a[i] = k; b[v[z]] = i; v.erase( v.begin() + z ); } answer( a, b ); return; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...