Submission #1254601

#TimeUsernameProblemLanguageResultExecution timeMemory
1254601tvgkCollecting Stamps 3 (JOI20_ho_t3)C++20
100 / 100
40 ms34120 KiB
#include<bits/stdc++.h>
using namespace std;
#define task "a"
#define se second
#define fi first
#define ll long long
#define ii pair<ll, ll>
const long mxN = 2e2 + 7, inf = 1e9 + 7;

int n, dp[mxN][mxN][mxN][2], l;
ii a[mxN];

int dis(int u, int v)
{
    return (v + l - u) % l;
}

int main()
{
    ios_base::sync_with_stdio(false);
    cin.tie(NULL);
    cout.tie(NULL);
//    freopen(task".INP", "r", stdin);
//    freopen(task".OUT", "w", stdout);

    cin >> n >> l;
    for (int i = 1; i <= n; i++)
        cin >> a[i].fi;
    for (int i = 1; i <= n; i++)
        cin >> a[i].se;

    /*
    dp[i][j][k][dir] = min time
    phai la i
    trai la j
    ket qua la k
    dir = 0 ben phai
    dir = 1 ben trai
    */

    for (int i = 0; i <= n; i++)
    {
        for (int j = i + 1; j <= n + 1; j++)
        {
            for (int k = 0; k <= n; k++)
            {
                for (int dir = 0; dir <= 1; dir++)
                    dp[i][j][k][dir] = inf;
            }
        }
    }

    int ans = 0;
    dp[0][n + 1][0][0] = 0;
    for (int i = 0; i <= n; i++)
    {
        for (int j = n + 1; j > i; j--)
        {
            for (int k = 0; k <= n; k++)
            {
                for (int dir = 0; dir <= 1; dir++)
                {
                    if (dp[i][j][k][dir] == inf)
                        continue;

                    ans = max(ans, k);

                    int cur = a[i].fi;
                    if (dir)
                        cur = a[j].fi;

                    // den i + 1
                    int nw = dp[i][j][k][dir] + dis(cur, a[i + 1].fi);
                    dp[i + 1][j][k + (nw <= a[i + 1].se)][0] = min(dp[i + 1][j][k + (nw <= a[i + 1].se)][0], nw);

                    // den j - 1
                    nw = dp[i][j][k][dir] + dis(a[j - 1].fi, cur);
                    dp[i][j - 1][k + (nw <= a[j - 1].se)][1] = min(dp[i][j - 1][k + (nw <= a[j - 1].se)][1], nw);
                }
            }
        }
    }
    cout << ans;
}

#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...