結果
問題 | No.999 てん vs. ほむ |
ユーザー | 双六 |
提出日時 | 2020-07-21 23:26:48 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 90 ms / 2,000 ms |
コード長 | 688 bytes |
コンパイル時間 | 303 ms |
コンパイル使用メモリ | 82,584 KB |
実行使用メモリ | 106,732 KB |
最終ジャッジ日時 | 2024-12-31 14:28:50 |
合計ジャッジ時間 | 2,908 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 20 |
ソースコード
import sys; input = sys.stdin.buffer.readline sys.setrecursionlimit(10**7) from collections import defaultdict con = 10 ** 9 + 7; INF = float("inf") def getlist(): return list(map(int, input().split())) #処理内容 def main(): N = int(input()) A = getlist() Lsum = [0] * N Rsum = [0] * N Lsum[0] = A[0] - A[1] Rsum[-1] = A[-1] - A[-2] for i in range(1, N): Lsum[i] = Lsum[i - 1] + A[2 * i] - A[2 * i + 1] Rsum[-1 - i] = Rsum[-i] + A[-1 - 2 * i] - A[-2 - 2 * i] if N == 1: print(abs(A[0] - A[1])) return ans = -INF for i in range(N - 1): ans = max(ans, Lsum[i] + Rsum[i + 1]) ans = max(ans, Lsum[-1], Rsum[0]) print(ans) if __name__ == '__main__': main()