結果
| 問題 | No.1715 Dinner 2 | 
| コンテスト | |
| ユーザー |  lam6er | 
| 提出日時 | 2025-03-31 17:37:46 | 
| 言語 | PyPy3 (7.3.15) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 1,279 ms / 2,000 ms | 
| コード長 | 2,434 bytes | 
| コンパイル時間 | 229 ms | 
| コンパイル使用メモリ | 82,060 KB | 
| 実行使用メモリ | 79,128 KB | 
| 最終ジャッジ日時 | 2025-03-31 17:38:42 | 
| 合計ジャッジ時間 | 14,412 ms | 
| ジャッジサーバーID (参考情報) | judge2 / judge5 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 1 | 
| other | AC * 38 | 
ソースコード
import sys
def main():
    sys.setrecursionlimit(1 << 25)
    N, D = map(int, sys.stdin.readline().split())
    dishes = []
    for _ in range(N):
        P, Q = map(int, sys.stdin.readline().split())
        dishes.append((P, Q))
    # Binary search boundaries
    low = -10**18
    high = 10**18
    answer = low
    def check(X):
        dp_prev = [-10**18] * N
        # Initialize day 1
        for j in range(N):
            Pj, Qj = dishes[j]
            step1 = 0 - Pj
            step2 = step1 + Qj
            if step1 >= X and step2 >= X:
                dp_prev[j] = step2
            else:
                dp_prev[j] = -10**18
        if D == 1:
            return any(val != -10**18 for val in dp_prev)
        for d in range(2, D+1):
            current_dp = [-10**18] * N
            # Precompute max values
            max_val = max(dp_prev)
            if max_val == -10**18:
                return False
            second_max = -10**18
            count_max = 0
            best_j = -1
            for j in range(N):
                if dp_prev[j] == max_val:
                    count_max += 1
                    best_j = j
                elif dp_prev[j] > second_max and dp_prev[j] < max_val:
                    second_max = dp_prev[j]
            for i in range(N):
                Ti = max(X + dishes[i][0], X + (dishes[i][0] - dishes[i][1]))
                if max_val < Ti:
                    continue  # even max_val is less than Ti, no way
                # Compute max_without_i
                if count_max > 1:
                    max_without_i = max_val
                else:
                    if best_j == i:
                        max_without_i = second_max
                    else:
                        max_without_i = max_val
                if max_without_i < Ti:
                    continue
                # compute new_E
                new_E = max_without_i - dishes[i][0] + dishes[i][1]
                current_dp[i] = new_E
            dp_prev = current_dp
            # Early termination if all current_dp are -inf
            if all(val == -10**18 for val in dp_prev):
                return False
        # After D days
        return any(val != -10**18 for val in dp_prev)
    while low < high:
        mid = (low + high + 1) // 2
        if check(mid):
            low = mid
        else:
            high = mid - 1
    print(low)
if __name__ == "__main__":
    main()
            
            
            
        