結果
問題 |
No.1104 オンライン点呼
|
ユーザー |
![]() |
提出日時 | 2025-06-12 14:20:01 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 837 bytes |
コンパイル時間 | 476 ms |
コンパイル使用メモリ | 82,176 KB |
実行使用メモリ | 109,520 KB |
最終ジャッジ日時 | 2025-06-12 14:20:04 |
合計ジャッジ時間 | 3,207 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 24 WA * 1 |
ソースコード
def main(): import sys input = sys.stdin.read data = input().split() idx = 0 N = int(data[idx]) idx += 1 K = int(data[idx]) idx += 1 if N == 1: print(0) return A = list(map(int, data[idx:idx + N])) idx += N B = list(map(int, data[idx:idx + N])) idx += N # Convert to 1-based indexing A = [0] + A B = [0] + B S = [0] * (N + 1) max_time = 0 for j in range(2, N + 1): if j == 2: S[j] = S[j - 1] + A[j - 1] + B[j] else: option1 = S[j - 1] + A[j - 1] + B[j] option2 = S[j - 2] + A[j - 2] + B[j] + K S[j] = min(option1, option2) if S[j] > max_time: max_time = S[j] print(max_time) if __name__ == "__main__": main()