結果
問題 | No.2463 ストレートフラッシュ |
ユーザー |
![]() |
提出日時 | 2023-09-08 21:58:48 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 244 ms / 2,000 ms |
コード長 | 813 bytes |
コンパイル時間 | 253 ms |
コンパイル使用メモリ | 82,172 KB |
実行使用メモリ | 78,464 KB |
最終ジャッジ日時 | 2024-06-26 14:58:27 |
合計ジャッジ時間 | 4,610 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 22 |
ソースコード
import sys input = sys.stdin.readline N, M = map(int, input().split()) ind = [[-1] * (N + 1) for i in range(M)] for i in range(N * M): n, m = map(int, input().split()) n, m = n - 1, m - 1 ind[m][n] = i for m in range(M): ind[m][-1] = ind[m][0] def solve(A): now = -1 card = 0 cnt = 0 while card != 5: nex = A[card] d = 5 - card n = (nex - now + d - 1)//d now += d * n cnt += n card = 0 for i in range(5): if A[i] <= now: card += 1 return cnt - 1 ans = 10 ** 18 for m in range(M): for i in range(N - 3): L = [] for j in range(5): L.append(ind[m][i + j]) L.sort() ans = min(ans, solve(L)) print(ans)