codeforces#P1398E. Two Types of Spells

    ID: 31389 远端评测题 3000ms 256MiB 尝试: 0 已通过: 0 难度: 8 上传者: 标签>binary searchdata structuresgreedyimplementationmathsortings*2200

Two Types of Spells

Description

Polycarp plays a computer game (yet again). In this game, he fights monsters using magic spells.

There are two types of spells: fire spell of power $x$ deals $x$ damage to the monster, and lightning spell of power $y$ deals $y$ damage to the monster and doubles the damage of the next spell Polycarp casts. Each spell can be cast only once per battle, but Polycarp can cast them in any order.

For example, suppose that Polycarp knows three spells: a fire spell of power $5$, a lightning spell of power $1$, and a lightning spell of power $8$. There are $6$ ways to choose the order in which he casts the spells:

  • first, second, third. This order deals $5 + 1 + 2 \cdot 8 = 22$ damage;
  • first, third, second. This order deals $5 + 8 + 2 \cdot 1 = 15$ damage;
  • second, first, third. This order deals $1 + 2 \cdot 5 + 8 = 19$ damage;
  • second, third, first. This order deals $1 + 2 \cdot 8 + 2 \cdot 5 = 27$ damage;
  • third, first, second. This order deals $8 + 2 \cdot 5 + 1 = 19$ damage;
  • third, second, first. This order deals $8 + 2 \cdot 1 + 2 \cdot 5 = 20$ damage.

Initially, Polycarp knows $0$ spells. His spell set changes $n$ times, each time he either learns a new spell or forgets an already known one. After each change, calculate the maximum possible damage Polycarp may deal using the spells he knows.

The first line contains one integer $n$ ($1 \le n \le 2 \cdot 10^5$) — the number of changes to the spell set.

Each of the next $n$ lines contains two integers $tp$ and $d$ ($0 \le tp_i \le 1$; $-10^9 \le d \le 10^9$; $d_i \neq 0$) — the description of the change. If $tp_i$ if equal to $0$, then Polycarp learns (or forgets) a fire spell, otherwise he learns (or forgets) a lightning spell.

If $d_i > 0$, then Polycarp learns a spell of power $d_i$. Otherwise, Polycarp forgets a spell with power $-d_i$, and it is guaranteed that he knew that spell before the change.

It is guaranteed that the powers of all spells Polycarp knows after each change are different (Polycarp never knows two spells with the same power).

After each change, print the maximum damage Polycarp can deal with his current set of spells.

Input

The first line contains one integer $n$ ($1 \le n \le 2 \cdot 10^5$) — the number of changes to the spell set.

Each of the next $n$ lines contains two integers $tp$ and $d$ ($0 \le tp_i \le 1$; $-10^9 \le d \le 10^9$; $d_i \neq 0$) — the description of the change. If $tp_i$ if equal to $0$, then Polycarp learns (or forgets) a fire spell, otherwise he learns (or forgets) a lightning spell.

If $d_i > 0$, then Polycarp learns a spell of power $d_i$. Otherwise, Polycarp forgets a spell with power $-d_i$, and it is guaranteed that he knew that spell before the change.

It is guaranteed that the powers of all spells Polycarp knows after each change are different (Polycarp never knows two spells with the same power).

Output

After each change, print the maximum damage Polycarp can deal with his current set of spells.

Samples

6
1 5
0 10
1 -5
0 5
1 11
0 -10
5
25
10
15
36
21