제출 #564632

#제출 시각아이디문제언어결과실행 시간메모리
564632CyanmondJakarta Skyscrapers (APIO15_skyscraper)C++17
22 / 100
26 ms51156 KiB
#pragma GCC target("avx2") #pragma GCC optimize("O3") #pragma GCC optimize("unroll-loops") #include <bits/stdc++.h> using namespace std; using i64 = int64_t; constexpr int inf = 1 << 30; #define REP(i, n) for (int i = 0; i < (n); ++i) #define REP3(i, l, r) for (int i = (l); i < (r); ++i) #define RVP(i, n) for (int i = (n - 1); i >= 0; --i) #define ALL(x) (x).begin(), (x).end() template <typename T> bool chmin(T &a, const T b) { if (a > b) { a = b; return true; } return false; } constexpr int V = 10000000; int main() { int N, M; cin >> N >> M; vector<pair<int, int>> A(M); REP(i, M) { cin >> A[i].first >> A[i].second; chmin(A[i].second, N); } int S = 0, T = 0; { const auto as = A[0], at = A[1]; sort(ALL(A), [](auto a, auto b) { if (a.second != b.second) { return a.second < b.second; } return a.first < b.first; }); REP(i, M) { if (A[i] == as) S = i; if (A[i] == at) T = i; } } vector<vector<pair<int, bool>>> lst(N); REP(i, M) { if ((not lst[A[i].first].empty()) and lst[A[i].first].back().first == A[i].second) { lst[A[i].first].back().second = true; continue; } else { lst[A[i].first].push_back({A[i].second, true}); } int f = A[i].first % A[i].second; while (f < N) { lst[f].push_back({A[i].second, false}); f += A[i].second; if (f == A[i].first) f += A[i].second; } } static array<int, 30010> size_r; REP(i, N) size_r[i + 1] = size_r[i] + (int)lst[i].size(); static array<pair<int, int>, V> pair_lr; static array<int, V> par; static array<vector<int>, 30010> chd, press; REP(i, N) { press[i].reserve(lst[i].size()); REP(j, (int)lst[i].size()) press[i].push_back(lst[i][j].first); } auto get_key = [&](int i, int w) { return lower_bound(ALL(press[i]), w) - press[i].begin(); }; REP(i, N) { int id = size_r[i]; for (const auto &[w, c] : lst[i]) { pair_lr[id] = {-1, -1}; par[id] = size_r[N] + i; if (c) chd[i].push_back(id); const int l = i - w; if (l >= 0) { const int id2 = size_r[l]++; pair_lr[id].first = id2; pair_lr[id2].second = id; } ++id; } } static array<int, V> dist; static array<bool, V> used; fill(ALL(dist), inf); fill(ALL(used), false); dist[size_r[N] + A[S].first] = 0; deque<int> deq; deq.push_back(size_r[N] + A[S].first); while (not deq.empty()) { const int f = deq.front(); deq.pop_front(); if (f == size_r[N] + A[T].first) break; if (used[f]) continue; used[f] = true; if (f >= size_r[N]) { for (const int &t : chd[f - size_r[N]]) { if (chmin(dist[t], dist[f])) { deq.push_front(t); } } } else { const auto &[l, r] = pair_lr[f]; if (l != -1 and chmin(dist[l], dist[f] + 1)) { deq.push_back(l); } if (r != -1 and chmin(dist[r], dist[f] + 1)) { deq.push_back(r); } const int pa = par[f]; if (chmin(dist[pa], dist[f])) { deq.push_front(pa); } } } auto ans = dist[size_r[N] + A[T].first]; if (ans == inf) ans = -1; cout << ans << endl; }

컴파일 시 표준 에러 (stderr) 메시지

skyscraper.cpp: In function 'int main()':
skyscraper.cpp:75:10: warning: variable 'get_key' set but not used [-Wunused-but-set-variable]
   75 |     auto get_key = [&](int i, int w) { return lower_bound(ALL(press[i]), w) - press[i].begin(); };
      |          ^~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...