結果
問題 |
No.1398 調和の魔法陣 (構築)
|
ユーザー |
👑 ![]() |
提出日時 | 2021-02-19 22:08:35 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,568 bytes |
コンパイル時間 | 414 ms |
コンパイル使用メモリ | 82,432 KB |
実行使用メモリ | 80,616 KB |
最終ジャッジ日時 | 2024-09-16 19:29:46 |
合計ジャッジ時間 | 39,083 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 WA * 2 |
other | AC * 11 WA * 17 |
ソースコード
""" 端を考えると 36以下は無理 角と、その隣が調和している必要がある ABXAB BAXBA XXXX ABXA ABXAB CDXCD XXXXX ABXAB CDXCD 探索した方がいい? 9**4 """ import sys def sol(ans): for i in range(H): for j in range(W): now = 0 for x in range(i-1,i+2): for y in range(j-1,j+2): if 0 <= x < H and 0 <= y < W: now += ans[x][y] if now != X: return False for i in ans: print (*i) sys.exit() W,H,X = map(int,input().split()) ans = [[0] * W for i in range(H)] # type1 for A in range(10): for i in range(H): for j in range(W): if i % 3 == 1: ans[i][j] = A else: ans[i][j] = 0 sol(ans) for A in range(10): for i in range(H): for j in range(W): if j % 3 == 1: ans[i][j] = A else: ans[i][j] = 0 sol(ans) #type2 for A in range(10): for B in range(10): for i in range(H): for j in range(W): if i % 3 == 2 or j % 3 == 2: ans[i][j] = 0 elif i % 3 == j % 3: ans[i][j] = A else: ans[i][j] = B sol(ans) #type3 for A in range(10): for i in range(H): for j in range(W): if i % 3 == j % 3 == 1: ans[i][j] = A else: ans[i][j] = 0 sol(ans) print (-1)