結果
| 問題 | No.2928 Gridpath | 
| コンテスト | |
| ユーザー |  ntuda | 
| 提出日時 | 2024-10-13 20:08:16 | 
| 言語 | PyPy3 (7.3.15) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 126 ms / 2,000 ms | 
| コード長 | 998 bytes | 
| コンパイル時間 | 336 ms | 
| コンパイル使用メモリ | 82,176 KB | 
| 実行使用メモリ | 76,864 KB | 
| 最終ジャッジ日時 | 2024-10-13 20:08:24 | 
| 合計ジャッジ時間 | 2,706 ms | 
| ジャッジサーバーID (参考情報) | judge4 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 3 | 
| other | AC * 20 | 
ソースコード
H, W = map(int, input().split())
Sx, Sy = [i - 1 for i in list(map(int, input().split()))]
G = tuple([i - 1 for i in list(map(int, input().split()))])
dir = [[1, 0], [0, 1], [0, -1], [-1, 0]]
nv = [[True] * W for _ in range(H)]
nv[Sx][Sy] = False
ans = 0
def dfs(x, y):
    global ans
    if (x, y) == G:
        ans += 1
        return
    for xd, yd in dir:
        x1 = x + xd
        y1 = y + yd
        if 0 <= x1 < H and 0 <= y1 < W:
            if nv[x1][y1]:
                f = True
                for xa, ya in dir:
                    x2 = x1 + xa
                    y2 = y1 + ya
                    if x2 == x and y2 == y:
                        continue
                    if 0 <= x2 < H and 0 <= y2 < W:
                        if nv[x2][y2] == False:
                            f = False
                            break
                if f:
                    nv[x1][y1] = False
                    dfs(x1, y1)
                    nv[x1][y1] = True
dfs(Sx, Sy)
print(ans)
            
            
            
        