# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
529721 | c28dnv9q3 | Nautilus (BOI19_nautilus) | C++17 | 1 ms | 204 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 <stdio.h>
typedef long long llong;
llong grid[8][505];
llong dp[2][8][505];
int main() {
int R, C, M;
scanf("%d %d %d", &R, &C, &M);
int Rc = (R + 63) / 63;
for(int r = 0; r < R; r++) {
for(int c = 0; c < C; c++) {
char chr;
for(chr = getchar(); chr != '.' && chr != '#'; chr = getchar());
if(chr == '.') grid[r/64][c] |= 1 << (r % 64);
dp[0][r/64][c] |= 1 << (r % 64);
}
}
int g = 1, pg = 0;
for(int i = 0; i < M; i++) {
char m;
for(m = getchar();
m != 'N' &&
m != 'E' &&
m != 'S' &&
m != 'W' &&
m != '?'
; m = getchar());
for(int rc = 0; rc < Rc; rc++) {
for(int c = 0; c < C; c++) {
dp[g][rc][c] = 0;
if((m == '?' || m == 'N')) dp[g][rc][c] |= (dp[pg][rc][c] << 1) | ((rc < Rc-1) ? (dp[pg][rc+1][c] >> 63) : 0);
if((m == '?' || m == 'S')) dp[g][rc][c] |= (dp[pg][rc][c] >> 1) | ((rc > 0) ? (dp[pg][rc-1][c] << 63) : 0);
if((m == '?' || m == 'E') && c > 0) dp[g][rc][c] |= dp[pg][rc][c-1];
if((m == '?' || m == 'W') && c < C-1) dp[g][rc][c] |= dp[pg][rc][c+1];
dp[g][rc][c] &= grid[rc][c];
}
}
pg = g;
g = (g+1) % 2;
}
int pc = 0;
for(int r = 0; r < R; r++) {
for(int c = 0; c < C; c++) {
if(dp[pg][r/64][c] & (1 << (r % 64))) pc++;
}
}
printf("%d\n", pc);
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... |