結果
| 問題 |
No.2157 崖
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2024-01-04 00:39:22 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 665 bytes |
| コンパイル時間 | 343 ms |
| コンパイル使用メモリ | 81,948 KB |
| 実行使用メモリ | 111,572 KB |
| 最終ジャッジ日時 | 2024-09-27 18:32:32 |
| 合計ジャッジ時間 | 9,158 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 16 WA * 6 |
ソースコード
from bisect import bisect_left
import sys
input = sys.stdin.readline
n, m = map(int, input().split())
D = []
for _ in range(n):
L = list(map(int, input().split()))
L.sort()
D.append(L)
INF = 10**18
DP = [[INF for _ in range(m)] for _ in range(n)]
for i in range(m):
DP[0][i] = 0
for i in range(n - 1):
for j in range(m):
if DP[i][j] == INF:
continue
prev_d = D[i][j]
idx = bisect_left(D[i + 1], prev_d)
if idx == m:
continue
res = max(DP[i][j], D[i + 1][idx] - prev_d)
DP[i + 1][idx] = min(DP[i + 1][idx], res)
ans = min(DP[n - 1])
if ans == INF:
ans = -1
print(ans)