Submission #955770

# Submission time Handle Problem Language Result Execution time Memory
955770 2024-03-31T12:03:30 Z vjudge1 Pinball (JOI14_pinball) C++17
51 / 100
1000 ms 12108 KB
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
vector<ll> lp, rp, wl, wr;
ll p, re = (1LL << 50);
void update(bool w, ll i, ll x)
{
    while (i > 0)
    {
        if (w)
            rp[i] = min(rp[i], x);
        else
            lp[i] = min(lp[i], x);
        i /= 2;
    }
    return;
}
ll qmin(bool w, ll l, ll r, ll i)
{
    if (wl[i] >= r || wr[i] <= l)
        return re;
    if (wl[i] >= l && wr[i] <= r)
    {
        if (w)
            return rp[i];
        else
            return lp[i];
    }
    return min(qmin(w, l, r, 2 * i), qmin(w, l, r, 2 * i + 1));
}
int main()
{
    ll m, n, i, j, k, a, b, w = 0, ma;
    cin >> m >> n;
    vector<vector<ll> > v, vv(m);
    vector<ll> d(m), s(3 * m);
    for (i = 0; i < m; i++)
    {
        cin >> j;
        v.push_back({j - 1, i, -1});
        cin >> j;
        v.push_back({j - 1, i, 1});
        cin >> j;
        v.push_back({j - 1, i, 0});
        cin >> d[i];
    }
    sort(v.begin(), v.end());
    if (v[0][0] || v[3 * m - 1][0] != n - 1)
    {
        cout << -1;
        return 0;
    }
    for (i = 0; i < 3 * m; i++)
    {
        if (!i)
            s[i] = 0;
        else if (v[i][0] > v[i - 1][0])
            s[i] = s[i - 1] + 1;
        else
            s[i] = s[i - 1];
        w = max(w, s[i]);
    }
    for (i = 0; i < 3 * m; i++)
        v[i] = {v[i][1], s[i], v[i][2]};
    sort(v.begin(), v.end());
    for (i = 0; i < m; i++)
        vv[i] = {v[3 * i][1], v[3 * i + 1][1], v[3 * i + 2][1]};
    p = w + 1;
    while (p != (p & -p))
        p++;
    lp.resize(2 * p);
    rp.resize(2 * p);
    wl.resize(2 * p);
    wr.resize(2 * p);
    for (i = p; i < 2 * p; i++)
    {
        lp[i] = rp[i] = re;
        wl[i] = i;
        wr[i] = i + 1;
    }
    lp[p] = rp[p + w] = 0;
    for (i = p - 1; i > 0; i--)
    {
        lp[i] = min(lp[2 * i], lp[2 * i + 1]);
        rp[i] = min(rp[2 * i], rp[2 * i + 1]);
        wl[i] = wl[2 * i];
        wr[i] = wr[2 * i + 1];
    }
    ma = re;
    ll ml, mr;
    for (i = 0; i < m; i++)
    {
        update(0, vv[i][1] + p, qmin(0, vv[i][0] + p, vv[i][1] + p, 1) + d[i]);
        update(1, vv[i][1] + p, qmin(1, vv[i][1] + 1 + p, vv[i][2] + 1 + p, 1) + d[i]);
        ml = lp[vv[i][0] + p];
        for (j = w; j > vv[i][0]; j--)
            ml = min(ml, lp[j + p]);
        mr = rp[vv[i][2] + p];
        for (j = 0; j < vv[i][2]; j++)
            mr = min(mr, rp[j + p]);
        ma = min(ma, ml + mr + d[i]);
    }
    for (j = 1; j <= w; j++)
        rp[j] = min(rp[j + p], rp[j + p - 1]);
    for (j = w - 1; j >= 0; j--)
        lp[j + p] = min(lp[j + p], lp[j + p + 1]);
    for (j = 0; j <= w; j++)
        ma = min(ma, lp[j + p] + rp[j + p]);
    if (ma < re)
        cout << ma;
    else
        cout << -1;
    return 0;
}

Compilation message

pinball.cpp: In function 'int main()':
pinball.cpp:33:20: warning: unused variable 'k' [-Wunused-variable]
   33 |     ll m, n, i, j, k, a, b, w = 0, ma;
      |                    ^
pinball.cpp:33:23: warning: unused variable 'a' [-Wunused-variable]
   33 |     ll m, n, i, j, k, a, b, w = 0, ma;
      |                       ^
pinball.cpp:33:26: warning: unused variable 'b' [-Wunused-variable]
   33 |     ll m, n, i, j, k, a, b, w = 0, ma;
      |                          ^
# Verdict Execution time Memory Grader output
1 Correct 1 ms 348 KB Output is correct
2 Correct 0 ms 348 KB Output is correct
3 Correct 0 ms 348 KB Output is correct
4 Correct 0 ms 348 KB Output is correct
5 Correct 0 ms 348 KB Output is correct
6 Correct 0 ms 348 KB Output is correct
7 Correct 0 ms 348 KB Output is correct
8 Correct 0 ms 344 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 1 ms 348 KB Output is correct
2 Correct 0 ms 348 KB Output is correct
3 Correct 0 ms 348 KB Output is correct
4 Correct 0 ms 348 KB Output is correct
5 Correct 0 ms 348 KB Output is correct
6 Correct 0 ms 348 KB Output is correct
7 Correct 0 ms 348 KB Output is correct
8 Correct 0 ms 344 KB Output is correct
9 Correct 1 ms 348 KB Output is correct
10 Correct 1 ms 348 KB Output is correct
11 Correct 1 ms 348 KB Output is correct
12 Correct 1 ms 348 KB Output is correct
13 Correct 1 ms 348 KB Output is correct
14 Correct 1 ms 348 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 1 ms 348 KB Output is correct
2 Correct 0 ms 348 KB Output is correct
3 Correct 0 ms 348 KB Output is correct
4 Correct 0 ms 348 KB Output is correct
5 Correct 0 ms 348 KB Output is correct
6 Correct 0 ms 348 KB Output is correct
7 Correct 0 ms 348 KB Output is correct
8 Correct 0 ms 344 KB Output is correct
9 Correct 1 ms 348 KB Output is correct
10 Correct 1 ms 348 KB Output is correct
11 Correct 1 ms 348 KB Output is correct
12 Correct 1 ms 348 KB Output is correct
13 Correct 1 ms 348 KB Output is correct
14 Correct 1 ms 348 KB Output is correct
15 Correct 1 ms 344 KB Output is correct
16 Correct 1 ms 348 KB Output is correct
17 Correct 5 ms 856 KB Output is correct
18 Correct 3 ms 604 KB Output is correct
19 Correct 2 ms 604 KB Output is correct
20 Correct 4 ms 604 KB Output is correct
21 Correct 2 ms 600 KB Output is correct
22 Correct 5 ms 960 KB Output is correct
23 Correct 5 ms 856 KB Output is correct
24 Correct 6 ms 856 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 1 ms 348 KB Output is correct
2 Correct 0 ms 348 KB Output is correct
3 Correct 0 ms 348 KB Output is correct
4 Correct 0 ms 348 KB Output is correct
5 Correct 0 ms 348 KB Output is correct
6 Correct 0 ms 348 KB Output is correct
7 Correct 0 ms 348 KB Output is correct
8 Correct 0 ms 344 KB Output is correct
9 Correct 1 ms 348 KB Output is correct
10 Correct 1 ms 348 KB Output is correct
11 Correct 1 ms 348 KB Output is correct
12 Correct 1 ms 348 KB Output is correct
13 Correct 1 ms 348 KB Output is correct
14 Correct 1 ms 348 KB Output is correct
15 Correct 1 ms 344 KB Output is correct
16 Correct 1 ms 348 KB Output is correct
17 Correct 5 ms 856 KB Output is correct
18 Correct 3 ms 604 KB Output is correct
19 Correct 2 ms 604 KB Output is correct
20 Correct 4 ms 604 KB Output is correct
21 Correct 2 ms 600 KB Output is correct
22 Correct 5 ms 960 KB Output is correct
23 Correct 5 ms 856 KB Output is correct
24 Correct 6 ms 856 KB Output is correct
25 Correct 245 ms 5284 KB Output is correct
26 Execution timed out 1043 ms 12108 KB Time limit exceeded
27 Halted 0 ms 0 KB -