結果
問題 |
No.1398 調和の魔法陣 (構築)
|
ユーザー |
👑 ![]() |
提出日時 | 2021-02-19 22:14:46 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 2,336 bytes |
コンパイル時間 | 182 ms |
コンパイル使用メモリ | 82,312 KB |
実行使用メモリ | 80,484 KB |
最終ジャッジ日時 | 2024-09-16 19:46:30 |
合計ジャッジ時間 | 30,613 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 WA * 2 |
other | AC * 1 WA * 27 |
ソースコード
""" 端を考えると 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) #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) #type2 for A in range(10): for B in range(10): for C in range(10): for D in range(10): if A+B+C+D == X: 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 == 0: ans[i][j] = A elif i % 3 == 0 and j % 3 == 1: ans[i][j] = B elif i % 3 == 1 and j % 3 == 0: ans[i][j] = C else: ans[i][j] = D sol(ans) print (-2) sys.exit() #print (ans) print (-1) """ if X == 0: for i in ans: print (*i) elif W == H == 1: if 0 <= X <= 9: print (X) else: print (-1) elif H == 1: if W % 3 != 2 or X >= 18: print (-1) else: if X % 4 != 0 or X: """