837. 新21点(逐句解释代码)

61 篇文章 0 订阅
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];
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值