package LeetCode.FiveHundredOneToOneThousand;
public class EightHundredAndThirtySeven {
public double new21Game(int N, int K, int W) {
// 从 1 - w 抽卡,当大于 n 的时候小于 k 的概率
// 我们从最后一格开始计算几率,每次抽卡的概率都是 1/w,在 N 之前我们都可以一次抽卡就达到
// N 之后不行,当可以一次就抽到之后我们要计算当抽到当前大小的卡之后抽到大于 N 的几率
// 即就是它后面W个格子的总和除以W
double[] dp = new double[K + W];
double s = 0.0;
// 计算从 k + w - 1到 N 的概率
for (int i = K;i < K + W;i++){
// 若 当前下标小于 N 则说明是可以通过一次抽卡达到的,否则就不行
dp[i] = (i <= N ? 1.0 : 0.0);
s += dp[i];
}
// 从中间往前,计算赢得概率
for (int i = K - 1; i >= 0; i--){
// 计算当下标为i的时候能抽到当前数字的概率
dp[i] = s / W;
// 计算当抽到当前大小的卡的时候,可以抽到 i + w 大小的卡的概率
s -=(dp[i + W] - dp[i]);
}
return dp[0];
}
}
837. 新21点(逐句解释代码)
最新推荐文章于 2021-03-02 19:37:04 发布