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.

×
G. Combining Slimes

time limit per test

2 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputYour friend recently gave you some slimes for your birthday. You have a very large amount of slimes with value 1 and 2, and you decide to invent a game using these slimes.

You initialize a row with *n* empty spaces. You also choose a number *p* to be used in the game. Then, you will perform the following steps while the last space is empty.

- With probability , you will choose a slime with value 1, and with probability , you will choose a slime with value 2. You place the chosen slime on the last space of the board.
- You will push the slime to the left as far as possible. If it encounters another slime, and they have the same value
*v*, you will merge the slimes together to create a single slime with value*v*+ 1. This continues on until the slime reaches the end of the board, or encounters a slime with a different value than itself.

You have played the game a few times, but have gotten bored of it. You are now wondering, what is the expected sum of all values of the slimes on the board after you finish the game.

Input

The first line of the input will contain two integers *n*, *p* (1 ≤ *n* ≤ 10^{9}, 1 ≤ *p* < 10^{9}).

Output

Print the expected sum of all slimes on the board after the game finishes. Your answer will be considered correct if its absolute or relative error does not exceed 10^{ - 4}.

Namely, let's assume that your answer is *a* and the answer of the jury is *b*. The checker program will consider your answer correct, if .

Examples

Input

2 500000000

Output

3.562500000000000

Input

10 1

Output

64.999983360007620

Input

100 123456789

Output

269.825611298854770

Note

In the first sample, we have a board with two squares, and there is a 0.5 probability of a 1 appearing and a 0.5 probability of a 2 appearing.

Our final board states can be 1 2 with probability 0.25, 2 1 with probability 0.375, 3 2 with probability 0.1875, 3 1 with probability 0.1875. The expected value is thus (1 + 2)·0.25 + (2 + 1)·0.375 + (3 + 2)·0.1875 + (3 + 1)·0.1875 = 3.5625.

Codeforces (c) Copyright 2010-2022 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Aug/17/2022 09:46:52 (j1).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|