#line 2 "library/template.hpp" // #pragma GCC target("avx2") // #pragma GCC optimize("O3") // #pragma GCC optimize("unroll-loops") #include using namespace std; // https://xn--kst.jp/blog/2019/08/29/cpp-comp/ // debug methods // usage: debug(x,y); #define CHOOSE(a) CHOOSE2 a #define CHOOSE2(a0, a1, a2, a3, a4, x, ...) x #define debug_1(x1) cout << #x1 << ": " << x1 << endl #define debug_2(x1, x2) \ cout << #x1 << ": " << x1 << ", " #x2 << ": " << x2 << endl #define debug_3(x1, x2, x3) \ cout << #x1 << ": " << x1 << ", " #x2 << ": " << x2 << ", " #x3 << ": " \ << x3 << endl #define debug_4(x1, x2, x3, x4) \ cout << #x1 << ": " << x1 << ", " #x2 << ": " << x2 << ", " #x3 << ": " \ << x3 << ", " #x4 << ": " << x4 << endl #define debug_5(x1, x2, x3, x4, x5) \ cout << #x1 << ": " << x1 << ", " #x2 << ": " << x2 << ", " #x3 << ": " \ << x3 << ", " #x4 << ": " << x4 << ", " #x5 << ": " << x5 << endl #ifdef LOCAL #define debug(...) \ CHOOSE((__VA_ARGS__, debug_5, debug_4, debug_3, debug_2, debug_1, ~)) \ (__VA_ARGS__) #else #define debug(...) #endif using ll = long long; using vl = vector; using Graph = vector>; using P = pair; #define all(v) v.begin(), v.end() template inline bool chmax(T &a, T b) { return ((a < b) ? (a = b, true) : (false)); } template inline bool chmin(T &a, T b) { return ((a > b) ? (a = b, true) : (false)); } #define rep1(i, n) for(ll i = 1; i <= ((ll)n); ++i) // https://trap.jp/post/1224/ template constexpr auto min(T... a) { return min(initializer_list>{a...}); } template constexpr auto max(T... a) { return max(initializer_list>{a...}); } template void input(T &...a) { (cin >> ... >> a); } template void input(vector &a) { for(T &x : a) cin >> x; } void print() { cout << '\n'; } template void print(const T &a, const Ts &...b) { cout << a; (cout << ... << (cout << ' ', b)); cout << '\n'; } template void print(vector x) { if(x.size()) { for(ll i = 0; i < x.size(); i++) { cout << x[i] << " \n"[i + 1 == x.size()]; } } } #define INT(...) \ int __VA_ARGS__; \ input(__VA_ARGS__) #define LL(...) \ long long __VA_ARGS__; \ input(__VA_ARGS__) #define STR(...) \ string __VA_ARGS__; \ input(__VA_ARGS__) #define REP1(a) for(int i = 0; i < a; i++) #define REP2(i, a) for(int i = 0; i < a; i++) #define REP3(i, a, b) for(int i = a; i < b; i++) #define REP4(i, a, b, c) for(int i = a; i < b; i += c) #define overload4(a, b, c, d, e, ...) e #define rep(...) overload4(__VA_ARGS__, REP4, REP3, REP2, REP1)(__VA_ARGS__) ll inf = 3e18; vl dx = {1, -1, 0, 0}; vl dy = {0, 0, 1, -1}; #line 2 "yukicoder/515/a.cpp" // #include // using namespace atcoder; // #include void solve() { LL(h, w); LL(sx, sy, gx, gy); sx--, sy--, gx--, gy--; ll ans = 0; Graph used(h, vl(w, 0)); used[sx][sy] = 1; auto dfs = [&](auto self, ll x, ll y) { // used[x][y] = 1; debug(x,y); if(x == gx && y == gy) { debug(ans); ans++; return; } rep(i, 4) { ll nx = x + dx[i]; ll ny = y + dy[i]; if(nx < 0 || nx >= h || ny < 0 || ny >= w) continue; if(used[nx][ny]) continue; ll cnt = 0; rep(j, 4) { ll nnx = nx + dx[j]; ll nny = ny + dy[j]; if(nnx < 0 || nnx >= h || nny < 0 || nny >= w) continue; cnt += used[nnx][nny]; } debug(nx,ny,cnt); if(cnt == 1) { used[nx][ny] = 1; self(self, nx, ny); used[nx][ny] = 0; } } }; dfs(dfs,sx,sy); // rep(i, 4) { // ll nx = sx + dx[i]; // ll ny = sy + dy[i]; // if(nx < 0 || nx >= h || ny < 0 || ny >= w) // continue; // dfs(dfs, nx, ny); // } print(ans); } int main() { ios::sync_with_stdio(false); std::cin.tie(nullptr); cout << std::setprecision(16); int t = 1; rep(_, t) { solve(); } }