837. 新21点(动态规划)

/**
 * 837. 新21点
 * @author wsq
 * @date 2020/10/26
	爱丽丝参与一个大致基于纸牌游戏 “21点” 规则的游戏,描述如下:
	爱丽丝以 0 分开始,并在她的得分少于 K 分时抽取数字。 抽取时,她从 [1, W] 的范围中随机获得一个整数作为分数进行累计,其中 W 是整数。 每次抽取都是独立的,其结果具有相同的概率。
	当爱丽丝获得不少于 K 分时,她就停止抽取数字。 爱丽丝的分数不超过 N 的概率是多少?
	
	示例 1:
	输入:N = 10, K = 1, W = 10
	输出:1.00000
	说明:爱丽丝得到一张卡,然后停止。

	示例 2:
	输入:N = 6, K = 1, W = 10
	输出:0.60000
	说明:爱丽丝得到一张卡,然后停止。
	在 W = 10 的 6 种可能下,她的得分不超过 N = 6 分。
	
	链接:https://leetcode-cn.com/problems/new-21-game
 */
package com.wsq.dp;

public class New21Game {
	/**
	 *	动态规划
	 *	按照从后向前顺序计算
	 * @param N
	 * @param K
	 * @param W
	 * @return
	 */
	public double new21Game(int N, int K, int W) {
        if(K == 0){
            return 1.0;
        }
        double[] f = new double[K + W];
        // 初始化转移方程
        for(int i = K; i <= N && i < K + W; i++){
            f[i] = 1.0;
        }
        // 为了计算方便,采用类似滑动窗口的方式,减少计算代价
        f[K-1] = 1.0 * Math.min(N - K + 1, W) / W;
        
        for(int i = K-2; i >=0; i--){
            f[i] = f[i+1] - (f[i + W + 1] - f[i + 1]) / W;
        }
        return f[0];
    }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值