Submission #980533

# Submission time Handle Problem Language Result Execution time Memory
980533 2024-05-12T08:25:33 Z vjudge1 Rainforest Jumps (APIO21_jumps) C++17
0 / 100
847 ms 1048576 KB
#include "jumps.h"
#include <bits/stdc++.h>
using namespace std;
const int N = 1e5 + 100, INF = 1e9;
vector<int> v[N];
int dist[N], n;
queue<int> q;

void bfs() {
    while (!q.empty()) {
        int cur = q.front();
        for (auto to : v[cur]) {
            if (dist[to] != INF)
                continue;
            dist[to] = dist[cur] + 1;
            q.push(to);
        }
    }
}

void init(int N, std::vector<int> H) {
    vector<pair<int, int>> ord(N);
    set<int> s;
    for (int i = 0; i < N; i++) {
        ord[i].first = H[i];
        ord[i].second = i;
    }
    n = N;
    sort(ord.begin(), ord.end());
    for (int i = 0; i < N; i++) {
        vector<int> todo;
        while (i < N) {
            todo.push_back(ord[i].second);
            auto l = lower_bound(s.begin(), s.end(), ord[i].second);
            if (l != s.end()) {
                v[ord[i].second].push_back(*l);
            }
            if (l == s.begin())
                continue;
            --l;
            v[ord[i].second].push_back(*l);
            if (i + 1 < N && ord[i].first == ord[i + 1].first) {
                i++;
                continue;
            }
            break;
        }
        for (auto it : todo)
            s.insert(it);
    }
}

int minimum_jumps(int A, int B, int C, int D) {
    int res = INF;
    for (int i = 0; i < n; i++) {
        dist[i] = INF;
    }
    for (int i = A; i <= B; i++) {
        dist[i] = 0;
        q.push(i);
    }
    bfs();
    for (int i = C; i <= D; i++) {
        res = min(res, dist[i]);
    }
    return (res == INF ? -1 : res);
}
# Verdict Execution time Memory Grader output
1 Runtime error 847 ms 1048576 KB Execution killed with signal 9
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Runtime error 652 ms 1048576 KB Execution killed with signal 9
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Runtime error 652 ms 1048576 KB Execution killed with signal 9
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Runtime error 694 ms 1048576 KB Execution killed with signal 9
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Runtime error 668 ms 1048576 KB Execution killed with signal 9
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Runtime error 668 ms 1048576 KB Execution killed with signal 9
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Runtime error 847 ms 1048576 KB Execution killed with signal 9
2 Halted 0 ms 0 KB -