This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
using namespace std;
#define REP(i, n) for (int i = 0; i < (n); ++i)
#define REP3(i, l, r) for (int i = (l); i < (r); ++i)
constexpr int inf = 1050000000;
constexpr array<pair<int, int>, 4> dxy = {{{-1, 0}, {0, 1}, {1, 0}, {0, -1}}};
template <class T> bool chmin(T &a, const T b) {
if (a > b) {
a = b;
return true;
}
return false;
}
int main() {
int N, W, H;
cin >> N >> W >> H;
vector<string> S(H);
for (auto &e : S) cin >> e;
vector<vector<array<pair<int, int>, 4>>> dest(H, vector<array<pair<int, int>, 4>>(W));
REP(i, H) REP(j, W) REP(k, 4) dest[i][j][k] = {-2, -2};
auto calc_dest = [&](auto &&self, const int h, const int w, const int k) -> pair<int, int> {
if (dest[h][w][k] == make_pair(-3, -3)) return dest[h][w][k] = {-1, -1};
if (dest[h][w][k] != make_pair(-2, -2)) return dest[h][w][k];
const int nh = h + dxy[k].first, nw = w + dxy[k].second;
if (nh < 0 or nw < 0 or nh >= H or nw >= W) return dest[h][w][k] = {h, w};
if (S[nh][nw] == 'x') return dest[h][w][k] = {h, w};
if (S[nh][nw] == 'A') {
dest[h][w][k] = {-3, -3};
return dest[h][w][k] = self(self, nh, nw, (k + 3) % 4);
}
if (S[nh][nw] == 'C') {
dest[h][w][k] = {-3, -3};
return dest[h][w][k] = self(self, nh, nw, (k + 1) % 4);
}
return dest[h][w][k] = self(self, nh, nw, k);
};
REP(i, H) REP(j, W) REP(k, 4) calc_dest(calc_dest, i, j, k);
vector dist(H, vector(W, vector(N, vector(N, inf))));
REP(i, H) REP(j, W) if (S[i][j] >= '1' and S[i][j] < '1' + N) {
const int v = S[i][j] - '1';
chmin(dist[i][j][v][v], 0);
REP(k, 4) {
if (dest[i][j][k] != make_pair(-1, -1))
chmin(dist[dest[i][j][k].first][dest[i][j][k].second][v][v], 1);
}
}
REP(length, N) {
REP(l, N - length) {
const int r = l + length;
REP(i, H) REP(j, W) {
REP3(d, l, r) chmin(dist[i][j][l][r], dist[i][j][l][d] + dist[i][j][d + 1][r]);
}
priority_queue<tuple<int, int, int>, vector<tuple<int, int, int>>,
greater<tuple<int, int, int>>>
pq;
REP(i, H) REP(j, W) if (dist[i][j][l][r] != inf) { pq.push({dist[i][j][l][r], i, j}); }
while (not pq.empty()) {
const auto [nc, h, w] = pq.top();
pq.pop();
if (nc > dist[h][w][l][r]) continue;
REP(k, 4) {
const int nh = dest[h][w][k].first, nw = dest[h][w][k].second;
if (nh < 0 or nh >= H or nw < 0 or nw >= W) continue;
if (chmin(dist[nh][nw][l][r], nc + 1)) {
pq.push({nc + 1, nh, nw});
}
}
}
}
}
int ans = inf;
REP(i, H) REP(j, W) chmin(ans, dist[i][j][0][N - 1]);
if (ans == inf) ans = -1;
cout << ans << endl;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |