Submission #5912477


Source Code Expand

#include <bits/stdc++.h>

#define CEIL(a,b) ((a) / (b) + ((a) % (b) == 0 ? 0 : 1))

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

constexpr int MOD = 1'000'000'007;
constexpr int INF = 1'000'000'001;
constexpr ll LLINF = 4'000'000'000'000'000'001;
// constexpr int INF = 2147483647; // 2 * 1e9
// constexpr ll LLINF = 9223372036854775807; // 9 * 1e18

const int dx[] = {1, 0, -1, 0, 1, -1, -1, 1, 0};
const int dy[] = {0, 1, 0, -1, 1, 1, -1, -1, 0};

int main(){
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    cout << fixed << setprecision(10);
    int n;
    cin >> n;
    vector<int> a(3*n);
    for(int i = 0; i < n*3; ++i){
        cin >> a[i];
    }
    priority_queue<int, vector<int>, greater<int>> que1;
    priority_queue<int> que2;
    vector<ll> fst(n+1), snd(n+1);
    for(int i = 0; i < n; ++i){
        fst[0] += a[i];
        que1.push(a[i]);
        snd[n] += a[3*n-1-i];
        que2.push(a[3*n-1-i]);
    }
    for(int i = 1; i <= n; ++i){
        que1.push(a[i+n-1]);
        fst[i] = fst[i-1] + a[i+n-1] - que1.top();
        que1.pop();
        que2.push(a[2*n-i]);
        snd[n-i] = snd[n-i+1] + a[2*n-i] - que2.top();
        que2.pop();
    }
    ll ans = -LLINF;
    for(int i = 0; i <= n; ++i){
        ans = max(ans, fst[i] - snd[i]);
    }
    cout << ans << "\n";
    return 0;
}

Submission Info

Submission Time
Task D - 3N Numbers
User hagyu_aya
Language C++14 (GCC 5.4.1)
Score 500
Code Size 1397 Byte
Status AC
Exec Time 57 ms
Memory 3964 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 1 ms 256 KB
1_17.txt AC 1 ms 256 KB
1_18.txt AC 1 ms 256 KB
1_19.txt AC 1 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 31 ms 3964 KB
2_01.txt AC 45 ms 3964 KB
2_02.txt AC 40 ms 3964 KB
2_03.txt AC 40 ms 3964 KB
2_04.txt AC 40 ms 3964 KB
2_05.txt AC 40 ms 3964 KB
2_06.txt AC 40 ms 3964 KB
2_07.txt AC 41 ms 3964 KB
2_08.txt AC 33 ms 3964 KB
2_09.txt AC 32 ms 3964 KB
2_10.txt AC 33 ms 3964 KB
2_11.txt AC 32 ms 3964 KB
2_12.txt AC 56 ms 3964 KB
2_13.txt AC 56 ms 3964 KB
2_14.txt AC 57 ms 3964 KB
2_15.txt AC 56 ms 3964 KB