답안 #108727

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
108727 2019-05-01T07:48:10 Z bibabas 중앙값 배열 (balkan11_medians) C++14
25 / 100
157 ms 12536 KB
#ifdef LOCAL
#define _GLIBCXX_DEBUG
#endif
#include <bits/stdc++.h>
#define ll long long
#define vi vector<int>
#define vvi vector<vi>
#define all(x) x.begin(), x.end()
#define pb push_back
#define mp make_pair

int INF = (int)2e9;

using namespace std;

template <class T>
istream& operator >>(istream &in, vector<T> &arr) {
    for (T &cnt : arr) {
        in >> cnt;
    }
    return in;
};

pair<int, int> t_left[(int)8e5], t_right[(int)8e5];
int t_add[(int)8e5];

void push(int v, int tl, int tr){
    t_left[v].first += t_add[v];
    t_right[v].first += t_add[v];
    if (tl != tr){
        t_left[2 * v].first += t_add[v];
        t_left[2 * v + 1].first += t_add[v];
        t_right[2 * v].first += t_add[v];
        t_right[2 * v + 1].first += t_add[v];
    }
    t_add[v] = 0;
}

void update(int v, int tl, int tr, int l, int r, int val){
    if (l > r)
        return;
    if (tl > r || l > tr)
        return;
    if (l <= tl && tr <= r){
        t_add[v] += val;
        push(v, tl, tr);
        return;
    }
    int tm = (tl + tr) / 2;
    update(2 * v, tl, tm, l, r, val);
    update(2 * v + 1, tm + 1, tr, l, r, val);
    if (t_left[2 * v].first >= t_left[2 * v + 1].first)
        t_left[v] = t_left[2 * v + 1];
    else
        t_left[v] = t_left[2 * v];
    t_right[v] = min(t_right[2 * v], t_right[2 * v + 1]);
}

pair<int, int> query_left(int v, int tl, int tr, int l, int r){
    if (l <= tl && tr <= r)
        return t_left[v];
    if (tl > r || l > tr)
        return make_pair(INF, -1);
    int tm = (tl + tr) / 2;
    auto a = query_left(2 * v, tl, tm, l, r), b = query_left(2 * v + 1, tm + 1, tr, l, r);
    if (a.first >= b.first)
        return b;
    else
        return a;
}

pair<int, int> query_right(int v, int tl, int tr, int l, int r){
    if (l <= tl && tr <= r)
        return t_right[v];
    if (tl > r || l > tr)
        return make_pair(INF, -1);
    int tm = (tl + tr) / 2;
    auto a = query_right(2 * v, tl, tm, l, r), b = query_right(2 * v + 1, tm + 1, tr, l, r);
    return min(a, b);
}

void build(int v, int tl, int tr){
    if (tl == tr) {
        t_left[v] = mp(0, tl);
        t_right[v] = mp(0, tl);
        return;
    }
    int tm = (tl + tr) / 2;
    build(2 * v, tl, tm);
    build(2 * v + 1, tm + 1, tr);
    t_left[v] = mp(0, tr);
    t_right[v] = mp(0, tl);
}

void solve() {
    int n; cin >> n;
    vi b(n); cin >> b;
    build(1, 1, 2 * n - 1);
    for (int i = 1; i < n; ++i){
        update(1, 1, 2 * n - 1, min(b[i - 1], b[i]) + 1, max(b[i], b[i - 1]) - 1, 1);
    }
    cout << b[0] << " ";
    update(1, 1, 2 * n - 1, b[0], b[0], 1);
    for (int i = 1; i < n; ++i){
        if (b[i] > b[i - 1]){
            auto a = query_right(1, 1, 2 * n - 1, b[i - 1], 2 * n - 1);
            update(1, 1, 2 * n - 1, a.second, a.second, 1);
            auto c = query_right(1, 1, 2 * n - 1, b[i - 1], 2 * n - 1);
            update(1, 1, 2 * n - 1, c.second, c.second, 1);
            update(1, 1, 2 * n - 1, b[i - 1] + 1, b[i] - 1, -1);
            cout << a.second << " " << c.second << " ";
        }
        if (b[i] == b[i - 1]){
            auto a = query_right(1, 1, 2 * n - 1, b[i - 1], 2 * n - 1);
            update(1, 1, 2 * n - 1, a.second, a.second, 1);
            auto c = query_left(1, 1, 2 * n - 1, 1, b[i - 1]);
            update(1, 1, 2 * n - 1, c.second, c.second, 1);
            update(1, 1, 2 * n - 1, b[i - 1] + 1, b[i] - 1, -1);
            cout << a.second << " " << c.second << " ";
        }
        if (b[i] < b[i - 1]){
            auto a = query_left(1, 1, 2 * n - 1, 1, b[i - 1]);
            update(1, 1, 2 * n - 1, a.second, a.second, 1);
            auto c = query_left(1, 1, 2 * n - 1, 1, b[i - 1]);
            update(1, 1, 2 * n - 1, c.second, c.second, 1);
            update(1, 1, 2 * n - 1, b[i] + 1, b[i - 1] - 1, -1);
            cout << a.second << " " << c.second << " ";
        }
    }
}

int main() {
#ifdef LOCAL
    freopen("input.txt", "r", stdin);
    freopen("output.txt", "w", stdout);
#else
    ios_base::sync_with_stdio(false);
    cin.tie(nullptr);
    cout.tie(nullptr);
#endif

    solve();

    return 0;
}
# 결과 실행 시간 메모리 Grader output
1 Correct 3 ms 384 KB Output is correct
2 Correct 2 ms 384 KB Output is correct
3 Correct 2 ms 384 KB Output is correct
4 Incorrect 2 ms 384 KB Not a permutation
5 Incorrect 2 ms 428 KB Not a permutation
6 Correct 2 ms 384 KB Output is correct
7 Correct 2 ms 384 KB Output is correct
8 Incorrect 3 ms 384 KB Not a permutation
9 Incorrect 3 ms 384 KB Not a permutation
10 Incorrect 3 ms 384 KB Not a permutation
11 Incorrect 3 ms 384 KB Not a permutation
12 Incorrect 3 ms 384 KB Not a permutation
13 Incorrect 3 ms 512 KB Not a permutation
# 결과 실행 시간 메모리 Grader output
1 Incorrect 6 ms 640 KB Not a permutation
2 Incorrect 8 ms 768 KB Not a permutation
3 Incorrect 12 ms 1152 KB Not a permutation
4 Incorrect 22 ms 2040 KB Not a permutation
5 Incorrect 42 ms 3576 KB Not a permutation
6 Incorrect 126 ms 6816 KB Not a permutation
7 Incorrect 157 ms 12536 KB Not a permutation