C. Gotta Go Fast
You’re trying to set the record on your favorite video game. The game consists of N levels, which must be completed sequentially in order to beat the game. You usually complete each level as fast as possible, but sometimes finish a level slower. Specifically, you will complete the i-th level in either $F_i $seconds or $S_i$ seconds, where $F_i < S_i$, and there’s a $P_i$ percent chance of completing it in $F_i$ seconds. After completing a level, you may decide to either continue the game and play the next level, or reset the game and start again from the first level. Both the decision and the action are instant.
Your goal is to complete all the levels sequentially in at most R total seconds. You want to minimize the expected amount of time playing before achieving that goal. If you continue and reset optimally, how much total time can you expect to spend playing?
Input
The first line of input contains integers N and R $(1\leq N\leq50,\sum F_i\leq R\leq\sum S_i)$, the number of levels and number of seconds you want to complete the game in, respectively. N lines follow. The ith such line contains integers $F_i, S_i, P_i (1 ≤ F_i < S_i ≤ 100, 80 ≤ P_i ≤ 99)$, the fast time for level i, the slow time for level i, and the probability (as a percentage) of completing level i with the fast time.
Output
Print the total expected time. Your answer must be correct within an absolute or relative error of $10 ^{- 9}$
Formally, let your answer be a, and the jury’s answer be b. Your answer will be considered correct, if$\frac{|a-b|}{max(1,|b|)}\leq 10^{-9}$ .
input
1 8
2 8 81
output
3.14
Note
In the first example, you never need to reset. There’s an 81% chance of completing the level in 2 seconds and a 19% chance of needing 8 seconds, both of which are within the goal time. The expected time is 0.81·2 + 0.19·8 = 3.14.
In the second example, you should reset after the first level if you complete it slowly. On average it will take 0.25 slow attempts before your first fast attempt. Then it doesn’t matter whether you complete the second level fast or slow. The expected time is 0.25·30 + 20 + 0.85·3 + 0.15·9 = 31.4.
令$F[i][j]$表示完成前$i$个关卡,当前用了$j$秒,完成所有关卡还需要的期望时间。那么可以得到转移
$$
F[i][j]=min{F[0][0],(F[i+1][j+A_{i+1}]+A_{i+1})\times\frac{P_i}{100}+(F[i+1][j+B_{i+1}]+B_{i+1})\times\frac{100-P_i}{100}}
$$
注意到这个转移方程里面有一项$F[0][0]$导致我们不能直接递推,这里就需要一种新姿势,二分答案。
先二分$F[0][0]$的值,然后带到这个$dp$里面去算,如果算出来的$F[0][0]$比二分的值大,说明当前二分的值不可行,那么$l=mid$,否则$r=mid$
另外要注意,初值不要给无穷大,全部赋成$mid$
代码:
1 |
|