Leetcode837.新21点

目录

      • 题目
      • [算法标签: 数学, 概率, 动态规划](#算法标签: 数学, 概率, 动态规划)
      • 思路
      • 代码

题目

837. 新 21 点

算法标签: 数学, 概率, 动态规划

思路

定义状态表示为 f i fi fi, 表示分数达到 i i i的时候的概率, 分析状态计算, 假设当前的分数是 i i i, 抽取到的牌得分数是 x x x, 那么当前状态就会转移到 f i + x fi + x fi+x, 状态转移方程如下

d p i = 1 maxPts ( d p i + 1 + d p i + 2 + ⋯ + d p i + maxPts ) dpi = \frac{1}{\text{maxPts}} \left( dpi+1 + dpi+2 + \cdots + dpi+\\text{maxPts} \right) dpi=maxPts1(dpi+1+dpi+2+⋯+dpi+maxPts)

计算时间复杂度, 外层枚举分数, 内层也需要枚举分数, 总的时间复杂度来到了 O ( n 2 ) O(n ^ 2) O(n2), 时间复杂度过高, 需要进行优化, 推 i = i − 1 i = i - 1 i=i−1时的表达式

d p i − 1 = 1 maxPts ( d p i + d p i + 1 + ⋯ + d p i + maxPts - 1 ) dpi - 1 = \frac{1}{\text{maxPts}} \left( dpi + dpi+1 + \cdots + dpi+\\text{maxPts - 1} \right) dpi−1=maxPts1(dpi+dpi+1+⋯+dpi+maxPts - 1)

设 t = m a x P t s t = maxPts t=maxPts, f i = f i + 1 × t + f i + 1 − f i + t + 1 t fi = \frac {fi + 1 \times t + fi + 1 - fi + t + 1}{t} fi=tfi+1×t+fi+1−fi+t+1, 整理后得到

f i = f i + 1 + f i + 1 − f i + t + 1 t fi = fi + 1 + \frac {fi + 1 - fi + t + 1} {t} fi=fi+1+tfi+1−fi+t+1

这样就将时间复杂度降低到 O ( n ) O(n) O(n)

代码

cpp 复制代码
#include <iostream>
#include <algorithm>
#include <cstring>
#include <vector>
#include <map>

using namespace std;

const int N = 2e4 + 10;

class Solution {
public:
    double new21Game(int n, int k, int maxPts) {
        if (k == 0) return 1.0;

        //当前分数是i, 并且分数不超过n的概率
        double f[N] = {0};
        for (int i = k; i <= n && i < k + maxPts; ++i) f[i] = 1.0;

        //计算当前分数是i再抽一张牌, 得分不超过n的概率
        f[k - 1] = 1.0 * min(n - k + 1, maxPts) / maxPts;

        for (int i = k - 2; i >= 0; --i) {
            f[i] = f[i + 1] + (f[i + 1] - f[i + maxPts + 1]) / maxPts;
        }

        return f[0];
    }
};
相关推荐
888CC++1 小时前
如何在 C 语言中进行程序调试?
前端·javascript·算法
暴躁小师兄数据学院1 小时前
【AI大数据工程师特训笔记】第16讲:大数据环境安装
大数据·hadoop·笔记·flink·spark·database
Lin_Aries_04212 小时前
最终成果报告:导航模型与无人机导航方向
笔记·具身智能·datawhale
pluviophile_s2 小时前
数据结构:第2讲:线性表
数据结构·笔记
(●—●)橘子……2 小时前
力扣第503场周赛练习理解
python·学习·算法·leetcode·职场和发展·周赛
明志数科4 小时前
4D时序标注技术详解:让机器人理解连续动作的数据基础
java·算法·机器人
feng_you_ying_li4 小时前
C++复习二,继承与多态
c++
AOwhisky4 小时前
MySQL 学习笔记(第一期):数据库基础与 MySQL 初探
运维·数据库·笔记·学习·mysql·云计算
小小de风呀4 小时前
de风——【从零开始学C++】(十一):list的基本使用和模拟实现
开发语言·c++·list