結果

問題 No.3513 Greedy Yokan Party
コンテスト
ユーザー yt142857
提出日時 2026-04-14 22:57:14
言語 PyPy3
(7.3.17)
コンパイル:
pypy3 -mpy_compile _filename_
実行:
pypy3 _filename_
結果
RE  
実行時間 -
コード長 1,831 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 179 ms
コンパイル使用メモリ 85,120 KB
実行使用メモリ 65,280 KB
最終ジャッジ日時 2026-04-24 20:51:23
合計ジャッジ時間 2,766 ms
ジャッジサーバーID
(参考情報)
judge2_0 / judge3_1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample RE * 1
other RE * 26
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

#gpt(一時チャット)
import sys


def solve():
    input = sys.stdin.readline
    N, K, L = map(int, input().split())
    A = list(map(int, input().split()))

    # 切れ目によって区切られる各区間の長さ
    d = [A[0]]
    for i in range(1, N):
        d.append(A[i] - A[i - 1])
    d.append(L - A[-1])

    M = N + 1
    limit = M - K + 1  # 2つの大きい部分列が使ってよい区間数の上限

    def feasible(H: int) -> bool:
        if H <= 0:
            return True

        INF = 10**18

        # pref[i] = d[0..i] の中で、和 >= H となる部分列の最小長
        pref = [INF] * M
        s = 0
        l = 0
        best = INF
        for r in range(M):
            s += d[r]
            while s >= H:
                best = min(best, r - l + 1)
                s -= d[l]
                l += 1
            if r > 0:
                pref[r] = min(pref[r - 1], best)
            else:
                pref[r] = best

        # suf[i] = d[i..M-1] の中で、和 >= H となる部分列の最小長
        suf = [INF] * M
        s = 0
        r = M - 1
        best = INF
        for l in range(M - 1, -1, -1):
            s += d[l]
            while s >= H:
                best = min(best, r - l + 1)
                s -= d[r]
                r -= 1
            if l < M - 1:
                suf[l] = min(suf[l + 1], best)
            else:
                suf[l] = best

        # 左側の部分列と右側の部分列を分けて選ぶ
        for i in range(M - 1):
            if pref[i] + suf[i + 1] <= limit:
                return True
        return False

    lo, hi = 0, L + 1
    while hi - lo > 1:
        mid = (lo + hi) // 2
        if feasible(mid):
            lo = mid
        else:
            hi = mid

    print(lo)


if __name__ == "__main__":
    solve()
0