結果
問題 | No.1077 Noelちゃんと星々4 |
ユーザー |
![]() |
提出日時 | 2021-07-19 02:58:12 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 58 ms / 2,000 ms |
コード長 | 1,311 bytes |
コンパイル時間 | 154 ms |
コンパイル使用メモリ | 81,900 KB |
実行使用メモリ | 68,180 KB |
最終ジャッジ日時 | 2024-07-16 06:43:58 |
合計ジャッジ時間 | 2,015 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 20 |
ソースコード
from heapq import *class slope_trick():def __init__(self):self.L = [] #mapheapself.R = [] #minheapself.shiftL = self.shiftR = 0self.min_f = 0# 関数に max(0,x-a) を加算def addR(self,a):a -= self.shiftLif self.L and -self.L[0] > a: self.min_f -= self.L[0] + av = heappushpop(self.L,-a)heappush(self.R,-v)# 関数に max(-,a-x) を加算def addL(self,a):a -= self.shiftRif self.R and a > self.R[0]: self.min_f += a - self.R[0]v = heappushpop(self.R,a)heappush(self.L,-v)# 関数に定数 a を加算def addconst(self,a):self.min_f += a# 関数の累積 min をとるdef reducemin(self):self.R = []# 関数を右に a 平行移動する、つまり f(x) \mapsto f(x-a) とするdef shift(self,a):self.shiftL += aself.shiftR += a# 関数の最小値を求めるdef getmin(self):return self.min_f#######################################################################import sysreadline = sys.stdin.readlinen = int(readline())*a, = map(int,readline().split())st = slope_trick()for ai in a:st.reducemin()st.addL(ai)st.addR(ai)print(st.getmin())