luogu#P16423. [IATI 2022] Fork

    ID: 16571 远端评测题 200ms 512MiB 尝试: 0 已通过: 0 难度: (无) 上传者: 标签>2022Special JudgeIATI(保加利亚/东欧)

[IATI 2022] Fork

Problem Description

Luca opened a Python shell and typed os.fork(), which spawned a second shell. After that, each time Luca pressed any key, it would randomly go to one of the two shells. Each shell has an input string (shown in the terminal), which is edited by the key presses going to that shell. Additionally, Luca sees the terminal and thus he knows which shell's input string was affected when he presses a key.

His keyboard has NN keys with distinct characters on them and Backspace. When a character key press goes to a shell, the character is simply appended to the end of its input string. When a Backspace key press goes to a shell, the last character of its input string is erased. If the shell's input string is empty, nothing happens to it (though Luca still sees the Backspace went there). Each key press has probability PP of going to the left shell and probability 1P1 - P of going to the right one.

Luca wants to type some fixed string a1a2aNa_1 a_2 \dots a_N consisting of NN distinct characters in both shells. He has already managed to type LL correct characters to the left shell and RR to the right one (i.e. the strings in the two shells are a1a2aLa_1 a_2 \dots a_L и a1a2aRa_1 a_2 \dots a_R). For example, consider P=0.3P = 0.3, N=2N = 2 (the string could be ab), L=0L = 0 and R=1R = 1. A possible sequence of events is:

Step Key Side Left shell Right shell
0 - - a
1 b Right ab
2 a aba
3 Left a
4 b Right abab
5 Backspace aba
6 Left -
7
8 Right ab
9 a Left a
10 b Right abb
11 Left ab
12 Backspace Right ab

In total, typing ab to both shells took 1212 key presses.

Let us define an incorrect character like so: a character in one of the two shells, which needs to be deleted at some point before typing the full string (and only that) to both shells. Luca has decided that he will never press Backspace, if there is no incorrect character in at least one of the shells. He has also decided that he will never press a key which will always result in an incorrect character. Luca is wondering what his optimal strategy would be under these constraints. In particular, he wants to know what is the minimum expected (average) number of key presses. Help Luca by writing a program fork.cpp which solves this problem.

Input Format

From the first and only line of the standard input, your program should read PP, NN, LL and RR.

Output Format

On the first and only line of the standard output, your program should print the computed answer to (preferably) 1212 digits of precision or more. You can use: std::cout << std::setprecision(12) << ans << std::endl;

0.3 2 0 1
16.7142857142857

Hint

Constraints

  • 0L,RN2×1070 \le L, R \le N \le 2 \times 10^7
  • 0.1P0.90.1 \le P \le 0.9

Subtasks and scoring

Subtask Points NN \le
11 1515 55
22 1010 1515
33 3535
44 1515 100100
55 450450
66 15001500
77 10610^6
88 55 2×1072 \times 10^7

To get the points for a given subtask, your solution must successfully pass all tests in it and in all previous subtasks. To pass a test, your solution must print an answer with a relative error at most 10810^{-8}, i.e.:

$$\frac{|yourAns - trueAns|}{trueAns} \le 10^{-8} \ (\text{where } \frac{0}{0} = 0)$$