AT_abc250_g [ABC250G] Stonks

题目描述

你将在 $N$ 天内进行 X 公司的股票交易。 作为拥有预知未来能力的人,你已经知道第 $i$ 天 X 公司的股价为每股 $P_i$ 日元。 你每天只能进行以下三种操作中的一种: - 以 $P_i$ 日元买入 X 公司的 1 股股票。 - 此时,你的持股数增加 1,所持现金减少 $P_i$ 日元。 - 以 $P_i$ 日元卖出 X 公司的 1 股股票。只有当你持有至少 1 股时才能进行此操作。 - 此时,你的持股数减少 1,所持现金增加 $P_i$ 日元。 - 什么都不做。 你在交易开始时拥有 $10^{100}$ 日元的现金,因此无需担心现金不足。 请你求出,在第 $N$ 天的操作结束后,你的现金增加额的最大可能值。 注意,在第 $N$ 天操作结束后,如果你还持有 X 公司的股票,这些股票在现金计算中按 $0$ 日元计价。

输入格式

输入以如下格式从标准输入给出。 > $N$ $P_1$ $P_2$ $\dots$ $P_N$

输出格式

请输出最大现金增加额,结果为整数。

说明/提示

## 限制条件 - 所有输入均为整数。 - $1 \leq N \leq 2 \times 10^5$ - $1 \leq P_i \leq 10^9$ ## 样例说明 1 通过如下操作,可以使现金增加 $16$ 日元,这也是最大值。 - 第 1 天,买入 1 股。持股 1 股,现金增加额为 $-2$ 日元。 - 第 2 天,卖出 1 股。持股 0 股,现金增加额为 $3$ 日元。 - 第 3 天,买入 1 股。持股 1 股,现金增加额为 $-1$ 日元。 - 第 4 天,买入 1 股。持股 2 股,现金增加额为 $-4$ 日元。 - 第 5 天,卖出 1 股。持股 1 股,现金增加额为 $3$ 日元。 - 第 6 天,买入 1 股。持股 2 股,现金增加额为 $2$ 日元。 - 第 7 天,卖出 1 股。持股 1 股,现金增加额为 $10$ 日元。 - 第 8 天,卖出 1 股。持股 0 股,现金增加额为 $16$ 日元。 由 ChatGPT 4.1 翻译