# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
154299 | two_sides | Robots (APIO13_robots) | C++17 | 592 ms | 101172 KiB |
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>
#define eb emplace_back
#define INF (0x3f3f3f3f)
using namespace std;
const int dx[] = {0, 1, 0, -1}, dy[] = {1, 0, -1, 0};
inline void fuk() { puts("-1"); exit(0); }
int D[9][9][505][505];
int PY[505][505][4], PX[505][505][4];
char A[505][505];
int N, H, W, Ans = INF;
vector<int> EV[505*505];
void spread(int D[][505]) {
int mn = INF;
for(int i = 1; i <= H; i++) for(int j = 1; j <= W; j++)
if(D[i][j] < mn) mn = D[i][j];
if(INF <= mn) fuk();
for(int i = 1; i <= H; i++) for(int j = 1; j <= W; j++)
if(D[i][j] <= mn + H*W)
EV[D[i][j]-mn].eb(i<<10|j);
for(int l = 0; l <= H*W; l++) {
auto &V = EV[l];
for(int key : V) {
int i = key>>10, j = key&((1<<10)-1);
for(int dr = 0, ni, nj; dr < 4; dr++) {
ni = PY[i][j][dr]; nj = PX[i][j][dr];
if(ni < 1 || nj < 1 || H < ni || W < nj) continue;
if(D[ni][nj] <= mn+l+1) continue;
D[ni][nj] = mn+l+1;
EV[l+1].eb(ni<<10|nj);
}
}
V.clear();
}
}
void f(int y, int x, int dr) {
int ndr = dr;
if('A' == A[y][x]) ndr++;
if('C' == A[y][x]) ndr--;
if(ndr < 0) ndr = 3; if(3 < ndr) ndr = 0;
PY[y][x][dr] = PX[y][x][dr] = -1;
int ny = y+dy[ndr], nx = x+dx[ndr];
if(!ny || !nx || H < ny || W < nx || 'x' == A[ny][nx]) {
PY[y][x][dr] = y;
PX[y][x][dr] = x;
return;
}
if(!PY[ny][nx][ndr]) f(ny, nx, ndr);
PY[y][x][dr] = PY[ny][nx][ndr];
PX[y][x][dr] = PX[ny][nx][ndr];
}
int main() {
scanf("%d%d%d", &N, &W, &H);
for(int i = 1; i <= H; i++) scanf(" %s", A[i]+1);
for(int i = 1; i <= H; i++) for(int j = 1; j <= W; j++) if('x' != A[i][j])
for(int dr = 0; dr < 4; dr++) if(!PY[i][j][dr]) f(i, j, dr);
fill(D[0][0][0], D[8][8][504]+505, INF);
for(int i = 1; i <= H; i++) for(int j = 1; j <= W; j++) if('1' <= A[i][j] && A[i][j] <= '9') {
int c = (A[i][j]&15) - 1;
D[c][c][i][j] = 0;
}
for(int i = 0; i < N; i++) spread(D[i][i]);
for(int l = 1; l < N; l++) {
for(int s = 0, e = l; e < N; s++, e++) {
for(int k = s; k < e; k++) {
for(int i = 1; i <= H; i++) for(int j = 1; j <= W; j++) {
int t = D[s][k][i][j] + D[k+1][e][i][j];
if(t < D[s][e][i][j]) D[s][e][i][j] = t;
}
}
spread(D[s][e]);
}
}
for(int i = 1; i <= H; i++) for(int j = 1; j <= W; j++)
if(D[0][N-1][i][j] < Ans) Ans = D[0][N-1][i][j];
cout << (INF <= Ans ? -1 : Ans) << endl;
return 0;
}
Compilation message (stderr)
# | 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... |