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

E. Chemistry Experiment

time limit per test

4 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputOne day two students, Grisha and Diana, found themselves in the university chemistry lab. In the lab the students found *n* test tubes with mercury numbered from 1 to *n* and decided to conduct an experiment.

The experiment consists of *q* steps. On each step, one of the following actions occurs:

- Diana pours all the contents from tube number
*p*_{i}and then pours there exactly*x*_{i}liters of mercury. - Let's consider all the ways to add
*v*_{i}liters of water into the tubes; for each way let's count the volume of liquid (water and mercury) in the tube with water with maximum amount of liquid; finally let's find the minimum among counted maximums. That is the number the students want to count. At that, the students don't actually pour the mercury. They perform calculations without changing the contents of the tubes.

Unfortunately, the calculations proved to be too complex and the students asked you to help them. Help them conduct the described experiment.

Input

The first line contains two integers *n* and *q* (1 ≤ *n*, *q* ≤ 10^{5}) — the number of tubes ans the number of experiment steps. The next line contains *n* space-separated integers: *h*_{1}, *h*_{2}, ..., *h*_{n} (0 ≤ *h*_{i} ≤ 10^{9}), where *h*_{i} is the volume of mercury in the *і*-th tube at the beginning of the experiment.

The next *q* lines contain the game actions in the following format:

- A line of form "1
*p*_{i}*x*_{i}" means an action of the first type (1 ≤*p*_{i}≤*n*; 0 ≤*x*_{i}≤ 10^{9}). - A line of form "2
*v*_{i}" means an action of the second type (1 ≤*v*_{i}≤ 10^{15}).

It is guaranteed that there is at least one action of the second type. It is guaranteed that all numbers that describe the experiment are integers.

Output

For each action of the second type print the calculated value. The answer will be considered correct if its relative or absolute error doesn't exceed 10^{ - 4}.

Examples

Input

3 3

1 2 0

2 2

1 2 1

2 3

Output

1.50000

1.66667

Input

4 5

1 3 0 1

2 3

2 1

1 3 2

2 3

2 4

Output

1.66667

1.00000

2.33333

2.66667

Codeforces (c) Copyright 2010-2019 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Oct/15/2019 03:30:56 (e2).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|