結果

問題 No.1797 永遠のグリッド
ユーザー 👑 ramdos
提出日時 2021-12-02 09:39:48
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 334 ms / 2,000 ms
コード長 755 bytes
コンパイル時間 967 ms
コンパイル使用メモリ 81,932 KB
実行使用メモリ 78,224 KB
最終ジャッジ日時 2024-10-09 06:20:19
合計ジャッジ時間 4,650 ms
ジャッジサーバーID
(参考情報)
judge3 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 27
権限があれば一括ダウンロードができます

ソースコード

diff #

H,W,K= map(int,input().split())
A=[[0 for i in range(H)]for j in range(W)]
B=[[0 for i in range(H)]for j in range(W)]
s=0
f=0
p=set()
while f==0:
  # print(A)
  r=0
  for i in range(H):
    if r==1:
        break
    for j in range(W):
      q=tuple([A[(j+b)%W][(i+a)%H] for a in range(H) for b in range(W)])
      if q in p:
        r=1
        break
  t=set()
  for i in range(W):
    for j in range(H):
      t.add(A[i][j])
  if r==0 and len(t)==K:
    p.add(tuple([A[b][a] for a in range(H) for b in range(W)]))
  s+=1
  ptr=0
  while True:
    if ptr==H*W:
        f=1
        break
    if(A[ptr%W][ptr//W]==K-1):
      ptr+=1
    else:
      A[ptr%W][ptr//W]+=1
      while ptr>=1:
        ptr-=1
        A[ptr%W][ptr//W]=0
      break
print(len(p))
0