# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
56201 | 2018-07-10T08:45:52 Z | 김현수(#2106) | Swap (BOI16_swap) | C++11 | 6 ms | 4984 KB |
#include<bits/stdc++.h> #define X first #define Y second using namespace std; typedef pair<int,int> pii; const int N = 200005, inf = 1e9; int n, a[N]; vector<pii> dt[N]; int geti (int I, int J) { for(int i=0;i<dt[I].size();i++) { if(dt[I][i].X > J) return dt[I][i-1].Y; } return dt[I].back().Y; } void calc (int I) { dt[I].push_back({0, I}); if(2*I+1 > n) { if(2*I <= n) dt[I].push_back({a[2*I], 2*I}); } else if(a[2*I] < a[2*I+1]) { dt[I].push_back({a[2*I], 2*I}); for(auto &T : dt[2*I]) { if(T.X <= a[2*I]) continue; dt[I].push_back(T); } } else { dt[I].push_back({a[2*I+1], 2*I+1}); for(int i=0,j=0;;) { auto &P = dt[2*I][i], &Q = dt[2*I+1][j]; if(max(P.X, Q.X) > a[2*I+1]) dt[I].push_back({max(P.X, Q.X), min(P.Y, Q.Y)}); bool A = (i+1 == dt[2*I].size()), B = (j+1 == dt[2*I+1].size()); if(A && B) break; else if(A) j++; else if(B) i++; else if(dt[2*I][i+1] < dt[2*I+1][j+1]) i++; else j++; } } } void exec (int I) { if(2*I+1 > n) { if(2*I <= n && a[I] > a[2*I]) swap(a[I], a[2*I]); } else if(a[2*I] < a[2*I+1]) { if(a[I] > a[2*I]) swap(a[I], a[2*I]); } else { int A = a[I], B = a[2*I]; if(A > B) swap(A, B); a[I] = a[2*I+1]; if(geti(2*I, A) < geti(2*I+1, A)) { a[2*I] = A; a[2*I+1] = B; } else { a[2*I] = B; a[2*I+1] = A; } } } int main() { scanf("%d",&n); for(int i=1;i<=n;i++) { scanf("%d",&a[i]); } for(int i=n;i>=1;i--) calc(i); for(int i=1;i<=n;i++) exec(i); for(int i=1;i<=n;i++) { printf("%d ",a[i]); } }
Compilation message
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Incorrect | 6 ms | 4984 KB | Output isn't correct |
2 | Halted | 0 ms | 0 KB | - |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Incorrect | 6 ms | 4984 KB | Output isn't correct |
2 | Halted | 0 ms | 0 KB | - |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Incorrect | 6 ms | 4984 KB | Output isn't correct |
2 | Halted | 0 ms | 0 KB | - |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Incorrect | 6 ms | 4984 KB | Output isn't correct |
2 | Halted | 0 ms | 0 KB | - |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Incorrect | 6 ms | 4984 KB | Output isn't correct |
2 | Halted | 0 ms | 0 KB | - |