Submission #966503

# Submission time Handle Problem Language Result Execution time Memory
966503 2024-04-20T02:07:54 Z Pring Palembang Bridges (APIO15_bridge) C++17
22 / 100
169 ms 20800 KB
#include <bits/stdc++.h>
using namespace std;

#ifdef MIKU
string dbmc = "\033[1;38;2;57;197;187m", dbrs = "\033[0m";
#define debug(x...) cout << dbmc << "[" << #x << "]: ", dout(x)
void dout() { cout << dbrs << endl; }
template <typename T, typename ...U>
void dout(T t, U ...u) { cout << t << (sizeof...(u) ? ", " : ""); dout(u...); }
#else
#define debug(...) 39
#endif

#define int long long
#define fs first
#define sc second
#define mp make_pair
#define FOR(i, j, k) for (int i = j, Z = k; i < Z; i++)
using ll = long long;
typedef pair<int, int> pii;

const int MXN = 100005;
int n, k;
vector<pii> v;
ll sum;

ll hl[MXN], hr[MXN];

struct SLOPE_TRICK {
    int val, now;
    multiset<int> L, R;
    void init() {
        val = 0;
        now = INT_MAX;
        L.clear();
        R.clear();
        L.insert(INT_MIN);
        R.insert(INT_MAX);
    }
    void add(int x) {
        val += abs(now - x);
        if (L.lower_bound(x) == L.end()) {
            if (x <= *R.begin()) {
                L.insert(x);
                R.insert(x);
                val -= abs(now - x);
                now = x;
            } else {
                R.insert(x);
                R.insert(x);
                L.insert(*R.begin());
                R.erase(R.begin());
                now = *R.begin();
            }
        } else {
            L.insert(x);
            L.insert(x);
            R.insert(*L.rbegin());
            L.erase(prev(L.end()));
            int cur = *R.begin();
            val -= (now - cur);
            now = cur;
        }
    }
    void COUT() {
        debug(now, val);
        for (auto i : L) cout << i << ' ';
        cout << endl;
        for (auto i : R) cout << i << ' ';
        cout << endl;
    }
} slt;

void miku() {
    cin >> k >> n;
    FOR(i, 0, n) {
        int a, b;
        char c, d;
        cin >> c >> a >> d >> b;
        if (a > b) swap(a, b);
        if (c == d) {
            sum += b - a;
        } else {
            sum += 1;
            v.push_back(mp(a, b));
        }
    }
    if (k == 1) {
        slt.init();
        for (auto &[a, b] : v) {
            slt.add(a);
            slt.add(b);
        }
        cout << sum + slt.val << '\n';
    } else {
        slt.init();
        sort(v.begin(), v.end(), [](pii a, pii b) -> bool {
            return a.fs + a.sc < b.fs + b.sc;
        });
        FOR(i, 0, v.size()) {
            slt.add(v[i].fs);
            slt.add(v[i].sc);
            hl[i] = slt.val;
        }
        slt.init();
        for (int i = v.size() - 1; i >= 0; i--) {
            slt.add(v[i].fs);
            slt.add(v[i].sc);
            hr[i] = slt.val;
        }
        // FOR(i, 0, v.size()) cout << hl[i] << ' ';
        // cout << endl;
        // FOR(i, 0, v.size()) cout << hr[i] << ' ';
        // cout << endl;
        int ans = LLONG_MAX;
        FOR(i, 0, v.size()) ans = min(ans, hl[i] + hr[i + 1]);
        cout << ans + sum << '\n';
    }
}

int32_t main() {
    cin.tie(0) -> sync_with_stdio(false);
    cin.exceptions(cin.failbit);
    miku();
    return 0;
}

Compilation message

bridge.cpp: In member function 'void SLOPE_TRICK::COUT()':
bridge.cpp:11:20: warning: statement has no effect [-Wunused-value]
   11 | #define debug(...) 39
      |                    ^~
bridge.cpp:66:9: note: in expansion of macro 'debug'
   66 |         debug(now, val);
      |         ^~~~~
# Verdict Execution time Memory Grader output
1 Correct 1 ms 344 KB Output is correct
2 Correct 0 ms 348 KB Output is correct
3 Correct 1 ms 604 KB Output is correct
4 Correct 1 ms 604 KB Output is correct
5 Correct 1 ms 604 KB Output is correct
6 Correct 1 ms 600 KB Output is correct
7 Correct 1 ms 600 KB Output is correct
8 Correct 1 ms 600 KB Output is correct
9 Correct 1 ms 604 KB Output is correct
10 Correct 1 ms 604 KB Output is correct
11 Correct 1 ms 604 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 1 ms 344 KB Output is correct
2 Correct 0 ms 344 KB Output is correct
3 Correct 1 ms 604 KB Output is correct
4 Correct 1 ms 604 KB Output is correct
5 Correct 1 ms 604 KB Output is correct
6 Correct 1 ms 604 KB Output is correct
7 Correct 1 ms 440 KB Output is correct
8 Correct 1 ms 604 KB Output is correct
9 Correct 1 ms 604 KB Output is correct
10 Correct 1 ms 604 KB Output is correct
11 Correct 1 ms 604 KB Output is correct
12 Correct 95 ms 20668 KB Output is correct
13 Correct 169 ms 20680 KB Output is correct
14 Correct 137 ms 18616 KB Output is correct
15 Correct 70 ms 12236 KB Output is correct
16 Correct 135 ms 20800 KB Output is correct
17 Correct 130 ms 20772 KB Output is correct
18 Correct 124 ms 20756 KB Output is correct
19 Correct 154 ms 20720 KB Output is correct
20 Correct 108 ms 20756 KB Output is correct
21 Correct 118 ms 20788 KB Output is correct
# Verdict Execution time Memory Grader output
1 Incorrect 0 ms 344 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 0 ms 348 KB Output isn't correct
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 0 ms 348 KB Output isn't correct
2 Halted 0 ms 0 KB -