This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
//Bismillahir-Rahmanir-Rahim
# include <bits/stdc++.h>
# define pb push_back
# define ff first
# define ss second
# define nl "\n"
# define sz(x) ((int)(x).size())
# define all(x) (x).begin(), (x).end()
# define deb(x) cerr << #x << " = " << x << endl;
# define pll pair <ll, ll>
# define pii pair <int, int>
typedef long long ll;
typedef unsigned long long ull;
typedef long double ld;
const ll maxn = 5e2 + 7;
const ll inf = 2e7 + 0;
const ll mod = 1e9 + 7;
const ll dx[] = {-1, 1, 0, 0};
const ll dy[] = {0, 0, -1, 1};
using namespace std;
mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());
ll n, m;
char c[maxn][maxn];
ll dist[maxn][maxn];
pii dir (char c)
{
if (c == 'N') return {-1, 0};
if (c == 'E') return {0, 1};
if (c == 'S') return {1, 0};
if (c == 'W') return {0, -1};
}
char f (pii p)
{
if (p == make_pair(-1, 0)) return 'N';
if (p == make_pair(0, 1)) return 'E';
if (p == make_pair(1, 0)) return 'S';
if (p == make_pair(0, -1)) return 'W';
}
bool in (ll x, ll y)
{
return (1 <= x && x <= n && 1 <= y && y <= m);
}
ll id (char c)
{
if (c == 'N') return 0;
if (c == 'E') return 1;
if (c == 'S') return 2;
if (c == 'W') return 3;
}
ll dst (char a, char b)
{
ll pos1 = id(a), pos2 = id(b);
if (pos1 <= pos2) return pos2 - pos1;
else return 4 - pos1 + pos2;
}
void ma1n (/* SABR */)
{
cin >> n >> m;
for (ll i = 1; i <= n; ++i)
{
for (ll j = 1; j <= m; ++j)
{
cin >> c[i][j];
dist[i][j] = inf;
}
}
set <pair <ll, pii> > q;
dist[1][1] = 0;
q.insert({dist[1][1], {1, 1}});
// for (char c : {'N', 'E', 'S', 'W'})
// {
// for (char b : {'N', 'E', 'S', 'W'})
// {
// cout << c << ' ' << b << ' ' << dst(c, b) << nl;
// }
// }
// exit(0);
while (!q.empty())
{
ll x = (q.begin() -> ss.ff);
ll y = (q.begin() -> ss.ss);
q.erase(q.begin());
// cout << x << ' ' << y << endl;
if (x == n && y == m) continue;
for (ll k = 0; k < 4; ++k)
{
ll add = dst(c[x][y], f({dx[k], dy[k]}));
ll nx = x + dx[k];
ll ny = y + dy[k];
if (in(nx, ny) && dist[nx][ny] > dist[x][y] + add && (c[nx][ny] != 'X' || (nx == n && ny == m)))
{
dist[nx][ny] = dist[x][y] + add;
q.insert({dist[nx][ny], {nx, ny}});
}
}
}
// for (ll i = 1; i <= n; ++i)
// {
// for (ll j = 1; j <= m; ++j)
// {
// cout << dist[i][j] << ' ';
// }
// cout << nl;
// }
if (dist[n][m] == inf)
{
cout << -1 << nl;
}
else
{
cout << dist[n][m] << nl;
}
}
int main()
{
ios::sync_with_stdio(false);
cin.tie(0); cout.tie(0);
// freopen("file.in", "r", stdin);
// freopen("file.out", "w", stdout);
int ttt = 1;
// cin >> ttt;
for (int test = 1; test <= ttt; ++test)
{
// cout << "Case " << test << ":" << '\n';
ma1n();
}
return 0;
}
// 998batrr | BbIWEJI 3A TObOU!!!
// tourist | BbIWEJI 3A TObOU!!!
Compilation message (stderr)
adventure.cpp: In function 'std::pair<int, int> dir(char)':
adventure.cpp:38:1: warning: control reaches end of non-void function [-Wreturn-type]
38 | }
| ^
adventure.cpp: In function 'char f(std::pair<int, int>)':
adventure.cpp:46:1: warning: control reaches end of non-void function [-Wreturn-type]
46 | }
| ^
adventure.cpp: In function 'll id(char)':
adventure.cpp:59:1: warning: control reaches end of non-void function [-Wreturn-type]
59 | }
| ^
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |