結果
問題 |
No.3185 Three Abs
|
ユーザー |
![]() |
提出日時 | 2025-06-20 21:48:11 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 573 ms / 2,000 ms |
コード長 | 563 bytes |
コンパイル時間 | 310 ms |
コンパイル使用メモリ | 82,224 KB |
実行使用メモリ | 136,628 KB |
最終ジャッジ日時 | 2025-06-20 21:48:24 |
合計ジャッジ時間 | 11,999 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 30 |
ソースコード
""" abs(S[l])+abs(S[r]-S[l])+abs(S[N]-S[r]) rを固定 abs(S[l])+abs(S[r]-S[l])を最小化する S[0],S[1],...,S[r-1]のうち、0とS[r]からの距離の和を最大化するものを選ぶ 結局最小値化最大値のいずれか """ for _ in range(int(input())): n = int(input()) A = list(map(int,input().split())) S = [0]*(n+1) for i in range(n): S[i+1] = S[i]+A[i] def f(x,y): return abs(x)+abs(y-x)+abs(S[n]-y) ans = -1<<60 mn = mx = 0 for s in S: mn,mx = min(mn,s),max(mx,s) ans = max(ans,f(mn,s),f(mx,s)) print(ans)