# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
27088 | khsoo01 | Swap (BOI16_swap) | C++11 | 0 ms | 0 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include<bits/stdc++.h>
using namespace std;
const int N = 200005, inf = 1e9;
int n, a[N];
vector<int> dt[N];
bool upd (int I, int J, int V) {
while(dt[I].size() <= J) dt[I].push_back(0);
dt[I][J] = max(dt[I][J], V);
}
int get (int I, int V) {
for(int i=0;i<dt[I].size();i++) {
if(V < dt[I][i]) return i;
}
return inf;
}
void calc (int I) {
if(2*I > n) {
upd(I, 0, inf);
return;
}
calc(2*I);
if(2*I+1 > n) {
upd(I, 0, a[2*I]); upd(I, 1, inf);
return;
}
calc(2*I+1);
if(a[2*I] < a[2*I+1]) {
for(auto &T : dt[2*I]) dt[I].push_back(T);
return;
}
int A = min(a[2*I], a[2*I+1]), B = a[2*I]+a[2*I+1]-A, F = 0;
upd(I, 0, A);
for(int i=0, j=0; i<dt[2*I].size() && j<dt[2*I+1].size(); ) {
int P = dt[2*I][i], Q = dt[2*I+1][j], R = min(P, Q);
if(!F) {
if(B < R) {
F = 1 + (i > j);
upd(I, min(i, j)+1, B);
}
else upd(I, min(i, j)+1, R);
}
if(F) upd(I, (flag-1?i:j)+1, R);
P < Q ? i++ : j++;
}
for(int i=1;i<dt[I].size();i++) {
dt[I][i] = max(dt[I][i], dt[I][i-1]);
}
}
void solve (int I) {
if(2*I > n) {
return;
}
if(2*I+1 > n) {
if(a[2*I] < a[I]) swap(a[2*I], a[I]);
return;
}
if(a[I] < a[2*I] && a[I] < a[2*I+1]) {
return;
}
if(a[2*I] < a[I] && a[2*I] < a[2*I+1]) {
swap(a[2*I], a[I]); return;
}
int A = min(a[I], a[2*I]), B = a[I]+a[2*I]-A;
a[I] = a[2*I+1];
if(get(2*I, A) <= get(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]);
}
calc(1);
for(int i=1;i<=n;i++) {
solve(i);
printf("%d ",a[i]);
}
}