数据结构学习 jz60 n个骰子的点数

关键词:动态规划 滚动数组优化

这道题还是不难的,就是特别纠结要怎么优化这个存储空间以及动态规划的方法,因为我觉得这个方法好原始,最后决定不优化了。最后发现题解也是这个原始的样子,我就放心了。用时38min。

题目:

思路:

类似跳楼梯,一次可以跳1-6级。

dp状态:

dpij:第i次抛筛子,第j小的点数集合的概率。

转移方程:

dpij=(dpi-1j-1+dpi-1j-2+...+dpi-1j-6)*(1/6)【这里注意范围】

i-1次抛筛子的集合点数的概率*1/6

初始化:第一次抛骰子,所有点数的概率都是1/6

复杂度计算:

时间复杂度O(n^2)

空间复杂度O(n)

代码:

我的dp状态的长度是num*6+1,因为想要dp的索引对应点数的集合。

抛第i次的时候,最大的点数集合是i*6,最小的点数集合是i。

cpp 复制代码
class Solution {
public:
    vector<double> statisticsProbability(int num) {
        vector<double> dp(6*num+1,1.0/6);
        dp[0]=0;
        for(int i=2;i<=num;++i)
        {
            for(int j=i*6;j>=i;--j)
            {
                dp[j]=0;
                for(int z=1;z<=6;++z)
                {
                    if(j-z>=i-1&&j-z<=(i-1)*6)//从上一轮里面选
                        dp[j]+=dp[j-z];
                }
                dp[j]*=1.0/6;
            }
        }
        vector<double> res(num*5+1);
        int j=0;
        for(int i=num;i<=num*6;++i,++j)
        {
            res[j]=dp[i];
        }
        return res;
    }
};
相关推荐
数智工坊1 小时前
周志华《Machine Learning》学习笔记--第七章--贝叶斯分类器
人工智能·笔记·神经网络·学习·机器学习
MartinYeung51 小时前
[论文学习]使用全同态加密实现实用隐私保护机器学习训练
人工智能·学习
lightqjx1 小时前
【算法】数据结构_单调栈
数据结构·算法·单调栈
网络与设备以及操作系统学习使用者2 小时前
多路由设备静态路由配置详解
运维·网络·学习·华为·智能路由器
计算机安禾2 小时前
【算法分析与设计】第44篇:随机化复杂度类:RP、BPP与去随机化猜想
java·数据结构·数据库·算法·机器学习
枕星而眠2 小时前
【数据结构】树与二叉树基础知识点总结
数据结构·c++·后端·算法·运维开发
坏柠2 小时前
从一个设备控制面板开始,系统学习 LVGL 界面开发
android·javascript·学习
创业之路&下一个五年2 小时前
委托、事件、发布-订阅模式全梳理(完整总结)
学习·总结
MartinYeung52 小时前
[论文学习] 全同态加密下的加密文字比较与子字串搜寻演算法延伸研究
学习·区块链·同态加密
Front思2 小时前
如何学习Shopify前端开发?
前端·学习