Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ICPC mode for virtual contests.
If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.
If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.
Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.

No tag edit access

The problem statement has recently been changed. View the changes.

×
B. Glass Half Spilled

time limit per test

2 secondsmemory limit per test

512 megabytesinput

standard inputoutput

standard outputThere are $$$n$$$ glasses on the table numbered $$$1, \ldots, n$$$. The glass $$$i$$$ can hold up to $$$a_i$$$ units of water, and currently contains $$$b_i$$$ units of water.

You would like to choose $$$k$$$ glasses and collect as much water in them as possible. To that effect you can pour water from one glass to another as many times as you like. However, because of the glasses' awkward shape (and totally unrelated to your natural clumsiness), each time you try to transfer any amount of water, half of the amount is spilled on the floor.

Formally, suppose a glass $$$i$$$ currently contains $$$c_i$$$ units of water, and a glass $$$j$$$ contains $$$c_j$$$ units of water. Suppose you try to transfer $$$x$$$ units from glass $$$i$$$ to glass $$$j$$$ (naturally, $$$x$$$ can not exceed $$$c_i$$$). Then, $$$x / 2$$$ units is spilled on the floor. After the transfer is done, the glass $$$i$$$ will contain $$$c_i - x$$$ units, and the glass $$$j$$$ will contain $$$\min(a_j, c_j + x / 2)$$$ units (excess water that doesn't fit in the glass is also spilled).

Each time you transfer water, you can arbitrarlly choose from which glass $$$i$$$ to which glass $$$j$$$ to pour, and also the amount $$$x$$$ transferred can be any positive real number.

For each $$$k = 1, \ldots, n$$$, determine the largest possible total amount of water that can be collected in arbitrarily chosen $$$k$$$ glasses after transferring water between glasses zero or more times.

Input

The first line contains a single integer $$$n$$$ ($$$1 \leq n \leq 100$$$) — the number of glasses.

The following $$$n$$$ lines describe the glasses. The $$$i$$$-th of these lines contains two integers $$$a_i$$$ and $$$b_i$$$ ($$$0 \leq b_i \leq a_i \leq 100$$$, $$$a_i > 0$$$) — capacity, and water amount currently contained for the glass $$$i$$$, respectively.

Output

Print $$$n$$$ real numbers — the largest amount of water that can be collected in $$$1, \ldots, n$$$ glasses respectively. Your answer will be accepted if each number is within $$$10^{-9}$$$ absolute or relative tolerance of the precise answer.

Example

Input

3 6 5 6 5 10 2

Output

7.0000000000 11.0000000000 12.0000000000

Note

In the sample case, you can act as follows:

- for $$$k = 1$$$, transfer water from the first two glasses to the third one, spilling $$$(5 + 5) / 2 = 5$$$ units and securing $$$2 + (5 + 5) / 2 = 7$$$ units;
- for $$$k = 2$$$, transfer water from the third glass to any of the first two, spilling $$$2 / 2 = 1$$$ unit and securing $$$5 + 5 + 2 / 2 = 11$$$ units;
- for $$$k = 3$$$, do nothing. All $$$5 + 5 + 2 = 12$$$ units are secured.

Codeforces (c) Copyright 2010-2022 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: May/21/2022 02:45:11 (i2).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|