Submission #1247434

#TimeUsernameProblemLanguageResultExecution timeMemory
1247434AnphatAirplane (NOI23_airplane)C++20
10 / 100
385 ms63728 KiB
#include <bits/stdc++.h>
using namespace std;

#define ll long long
#define f first
#define s second
#define sz(a) (int)((a).size())
#define all(a) (a).begin(), (a).end()
#define uni(a) sort(all(a)), (a).resize(unique(all(a)) - (a).begin())

typedef tuple <int, int, int> tp;
typedef pair <int, int> ii;

const int N = 4e3 + 10;

int n, m, a[N], f[N][N], mx;
priority_queue <tp, vector <tp>, greater <tp>> pq;
vector <int> graph[N];
ii edge[N];

void solve() {
    cin >> n >> m;
    for (int i = 1; i <= n; i++) {
        cin >> a[i];
        mx = max(mx, a[i]);
    }

    for (int i = 1; i <= m; i++) {
        int u, v;
        cin >> u >> v;
        graph[u].push_back(v);
        graph[v].push_back(u);
    }

    memset(f, 0x3f, sizeof(f));
    f[1][0] = 0;
    pq.push({0, 1, 0});

    while (sz(pq)) {
        ll w, u, i; tie(w, u, i) = pq.top(); pq.pop();
        if (w > f[u][i]) continue;

        for (int v : graph[u]) {
            if (i >= a[v]) {
                if (f[v][i] > f[u][i] + 1) {
                    f[v][i] = f[u][i] + 1;
                    pq.push({f[v][i], v, i});
                }
            }

            if (i < mx && i + 1 >= a[v]) {
                if (f[v][i + 1] > f[u][i] + 1) {
                    f[v][i + 1] = f[u][i] + 1;
                    pq.push({f[v][i + 1], v, i + 1});
                }
            }

            if (i > 0 && i - 1 >= a[v]) {
                if (f[v][i - 1] > f[u][i] + 1) {
                    f[v][i - 1] = f[u][i] + 1;
                    pq.push({f[v][i - 1], v, i - 1});
                }
            }
        }

        if (i < mx && f[u][i + 1] > f[u][i] + 1) {
            f[u][i + 1] = f[u][i] + 1;
            pq.push({f[u][i + 1], u, i + 1});
        }

        if (i > 0 && f[u][i - 1] > f[u][i] + 1) {
            f[u][i - 1] = f[u][i] + 1;
            pq.push({f[u][i - 1], u, i - 1});
        }
    }

    cout << f[n][0] << '\n';
}

int main() {
    ios_base::sync_with_stdio(0);
    cin.tie(0); cout.tie(0);

    // freopen("airplane.inp", "r", stdin);
    // freopen("airplane.out", "w", stdout);

    int t = 1;
    // cin >> t;

    while (t--) {
        solve();
    }

    return 0;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...