Submission #5906065


Source Code Expand

#include <bits/stdc++.h>

#define REP(i, e) for(int (i) = 0; (i) < (e); ++(i))
#define FOR(i, b, e) for(int (i) = (b); (i) < (e); ++(i))
#define ALL(c) (c).begin(), (c).end()
#define MIN(c) (*min_element(ALL(c))) 
#define MAX(c) (*max_element(ALL(c)))
#define ACC(c) (accumulate(ALL(c), 0))
#define MP(a, b) (make_pair((a), (b)))
#define ENDL "\n"
#define PRINT(x) cout << (x) << ENDL

using namespace std;
using ll = long long;
using pint = pair<int, int>;
using pll = pair<ll, ll>;

inline int in(int& a) {return scanf("%d", &a);}
inline void out(int n) {printf("%d\n", n);}
template<typename T> inline void swap(T& a, T& b) {T tmp = a; a = b; b = tmp;}
auto pint_compare = [](pint x, pint y) -> bool{return (x.first < y.first);};


int N;
int a[300000];
ll A[100001], B[100001];
priority_queue<int, vector<int>, greater<int> > L;
priority_queue<int, vector<int>, less<int> > R;

signed main(){
    in(N);
    REP(i, 3 * N) in(a[i]);
    REP(i, N){
        L.push(a[i]);
    }
    REP(i, N){
        R.push(a[i + 2 * N]);
    }
    A[0] = accumulate(a, a + N, 0LL);
    B[N] = accumulate(a + 2 * N, a + 3 * N, 0LL);
    REP(i, N){
        L.push(a[i + N]);
        A[i + 1] += A[i] + a[i + N] - L.top();
        L.pop();
    }
    REP(i, N){
        R.push(a[2 * N - 1 - i]);
        B[N - i - 1] += B[N - i] + a[2 * N - 1 - i] - R.top();
        R.pop();
    }
    ll m = A[0] - B[0];
    FOR(i, 1, N + 1) m = max(m, A[i] - B[i]);
    PRINT(m);
    return 0;
}

Submission Info

Submission Time
Task D - 3N Numbers
User N45h
Language C++14 (GCC 5.4.1)
Score 500
Code Size 1517 Byte
Status AC
Exec Time 60 ms
Memory 3832 KB

Judge Result

Set Name Sample Subtask All
Score / Max Score 0 / 0 300 / 300 200 / 200
Status
AC × 3
AC × 27
AC × 43
Set Name Test Cases
Sample 0_00.txt, 0_01.txt, 0_02.txt
Subtask 0_00.txt, 0_01.txt, 0_02.txt, 1_00.txt, 1_01.txt, 1_02.txt, 1_03.txt, 1_04.txt, 1_05.txt, 1_06.txt, 1_07.txt, 1_08.txt, 1_09.txt, 1_10.txt, 1_11.txt, 1_12.txt, 1_13.txt, 1_14.txt, 1_15.txt, 1_16.txt, 1_17.txt, 1_18.txt, 1_19.txt, 1_20.txt, 1_21.txt, 1_22.txt, 1_23.txt
All 0_00.txt, 0_01.txt, 0_02.txt, 1_00.txt, 1_01.txt, 1_02.txt, 1_03.txt, 1_04.txt, 1_05.txt, 1_06.txt, 1_07.txt, 1_08.txt, 1_09.txt, 1_10.txt, 1_11.txt, 1_12.txt, 1_13.txt, 1_14.txt, 1_15.txt, 1_16.txt, 1_17.txt, 1_18.txt, 1_19.txt, 1_20.txt, 1_21.txt, 1_22.txt, 1_23.txt, 2_00.txt, 2_01.txt, 2_02.txt, 2_03.txt, 2_04.txt, 2_05.txt, 2_06.txt, 2_07.txt, 2_08.txt, 2_09.txt, 2_10.txt, 2_11.txt, 2_12.txt, 2_13.txt, 2_14.txt, 2_15.txt
Case Name Status Exec Time Memory
0_00.txt AC 1 ms 256 KB
0_01.txt AC 1 ms 256 KB
0_02.txt AC 1 ms 256 KB
1_00.txt AC 1 ms 256 KB
1_01.txt AC 1 ms 256 KB
1_02.txt AC 1 ms 256 KB
1_03.txt AC 1 ms 256 KB
1_04.txt AC 1 ms 256 KB
1_05.txt AC 1 ms 256 KB
1_06.txt AC 1 ms 256 KB
1_07.txt AC 1 ms 256 KB
1_08.txt AC 1 ms 256 KB
1_09.txt AC 2 ms 256 KB
1_10.txt AC 2 ms 256 KB
1_11.txt AC 2 ms 256 KB
1_12.txt AC 2 ms 256 KB
1_13.txt AC 2 ms 256 KB
1_14.txt AC 2 ms 256 KB
1_15.txt AC 2 ms 256 KB
1_16.txt AC 2 ms 256 KB
1_17.txt AC 2 ms 256 KB
1_18.txt AC 2 ms 256 KB
1_19.txt AC 2 ms 256 KB
1_20.txt AC 2 ms 256 KB
1_21.txt AC 2 ms 256 KB
1_22.txt AC 2 ms 256 KB
1_23.txt AC 2 ms 256 KB
2_00.txt AC 32 ms 3832 KB
2_01.txt AC 45 ms 3832 KB
2_02.txt AC 44 ms 3832 KB
2_03.txt AC 44 ms 3832 KB
2_04.txt AC 44 ms 3832 KB
2_05.txt AC 44 ms 3832 KB
2_06.txt AC 44 ms 3832 KB
2_07.txt AC 45 ms 3832 KB
2_08.txt AC 37 ms 3832 KB
2_09.txt AC 37 ms 3832 KB
2_10.txt AC 38 ms 3832 KB
2_11.txt AC 37 ms 3832 KB
2_12.txt AC 59 ms 3832 KB
2_13.txt AC 60 ms 3832 KB
2_14.txt AC 60 ms 3832 KB
2_15.txt AC 60 ms 3832 KB