結果

問題 No.1949 足し算するだけのパズルゲーム(2)
ユーザー hiragn
提出日時 2022-12-14 20:08:07
言語 Python3
(3.13.1 + numpy 2.2.1 + scipy 1.14.1)
結果
WA  
実行時間 -
コード長 932 bytes
コンパイル時間 550 ms
コンパイル使用メモリ 12,800 KB
実行使用メモリ 31,872 KB
最終ジャッジ日時 2024-11-08 11:44:57
合計ジャッジ時間 10,707 ms
ジャッジサーバーID
(参考情報)
judge3 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 20 WA * 6
権限があれば一括ダウンロードができます

ソースコード

diff #
プレゼンテーションモードにする

from heapq import heapify, heappop, heappush
def main():
h, w, sy, sx = map(int, input().split())
sy -= 1
sx -= 1
a = [list(map(int, input().split())) for _ in range(h)]
used = [[False] * w for _ in range(h)]
used[sy][sx] = True
hq = [(a[sy][sx], sy, sx)]
heapify(hq)
cnt = 0
cur_atk = a[sy][sx]
a[sy][sx] = 0
dx = [1, 0, -1, 0, 1, -1, -1, 1]
dy = [0, 1, 0, -1, 1, 1, -1, -1]
while hq:
atk, y, x = heappop(hq)
if cnt > 0 and cur_atk <= atk:
exit(print("No"))
cnt += 1
cur_atk += atk
for i in range(4):
ny = y + dy[i]
nx = x + dx[i]
if 0 <= ny < h and 0 <= nx < w and not used[ny][nx]:
used[ny][nx] = True
heappush(hq, (a[ny][nx], ny, nx))
if cnt == h * w:
print("Yes")
else:
print("No")
if __name__ == "__main__":
main()
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
0