当前位置: 首页 > news >正文

免费网站在线客服企业宣传推广

免费网站在线客服,企业宣传推广,谁有做网站比较厉害的,技术支持 沧州辉煌网络-网站建设❓ 剑指 Offer 60. n个骰子的点数 难度:中等 把 n 个骰子扔在地上,所有骰子朝上一面的点数之和为 s 。输入 n,打印出s的所有可能的值出现的概率。 你需要用一个浮点数数组返回答案,其中第 i 个元素代表这 n 个骰子所能掷出的点…

❓ 剑指 Offer 60. n个骰子的点数

难度:中等

n 个骰子扔在地上,所有骰子朝上一面的点数之和为 s 。输入 n,打印出s的所有可能的值出现的概率。

你需要用一个浮点数数组返回答案,其中第 i 个元素代表这 n 个骰子所能掷出的点数集合中第 i 小的那个的概率。

示例 1:

输入: 1
输出: [0.16667,0.16667,0.16667,0.16667,0.16667,0.16667]

示例 2:

输入: 2
输出: [0.02778,0.05556,0.08333,0.11111,0.13889,0.16667,0.13889,0.11111,0.08333,0.05556,0.02778]

限制

  • 1 <= n <= 11

💡思路:动态规划

使用一个二维数组 dp 存储点数出现的次数,其中 dp[i][j] 表示前 i 个骰子产生点数 j 的次数。

只看第 n 枚骰子,它的点数可能为 1, 2, 3, ... , 6 ,因此投掷完 n 枚骰子后点数 j 出现的次数,可以由投掷完 n−1 枚骰子后,对应点数 j−1, j−2, j−3, ..., j−6 出现的次数之和转化过来。

for (第n枚骰子的点数 k = 1; k <= 6; k++) {dp[n][j] += dp[n-1][j - k]
}

写成数学公式是这样的:
d p [ n ] [ j ] = ∑ i = 1 6 d p [ n − 1 ] [ j − k ] dp[n][j]=\sum_{i=1}^6dp[n-1][j-k] dp[n][j]=i=16dp[n1][jk]
n 表示阶段,j 表示投掷完 n 枚骰子后的点数和,k 表示第 n 枚骰子会出现的六个点数。

⭐️ 空间优化: 旋转数组

观察发现每个阶段的状态都只和它前一阶段的状态有关,因此我们不需要用额外的一维来保存所有阶段。

  • 用两个一维数组交替变换存储。

🍁代码:(C++、Java)

C++

class Solution {
public:vector<double> dicesProbability(int n) {int maxsum = n * 6;vector<vector<long long>> dp(n + 1, vector<long long>(maxsum + 1));for(int i = 1; i <= 6; i++){dp[1][i] = 1;}for(int i = 2; i <= n; i++){for(int j = i; j <= i * 6; j++){for(int k = 1; k <= 6 && k <= j; k++){dp[i][j] += dp[i - 1][j - k];}}}long long totalnum = pow(6, n);vector<double> ans(n * 5 + 1);for(int i = n; i <= maxsum; i++){ans[i - n] = (double)dp[n][i] / totalnum;}return ans;}
};

⭐️ 空间优化: 旋转数组

C++

class Solution {
public:vector<double> dicesProbability(int n) {int maxsum = n * 6;vector<vector<long long>> dp(2, vector<long long>(maxsum + 1));for(int i = 1; i <= 6; i++){dp[0][i] = 1;}int flag = 1; //旋转标记for(int i = 2; i <= n; i++, flag = 1 - flag){for(int j = 0; j <= i * 6; j++){dp[flag][j] = 0; //旋转数组清零}for(int j = i; j <= i * 6; j++){for(int k = 1; k <= 6 && k < j; k++){dp[flag][j] += dp[1 - flag][j - k];}}}long long totalnum = pow(6, n);vector<double> ans(n * 5 + 1);for(int i = n; i <= maxsum; i++){ans[i - n] = (double)dp[1 - flag][i] / totalnum;}return ans;}
};

Java

class Solution {public double[] dicesProbability(int n) {int maxsum = n * 6;long[][] dp = new long[2][maxsum + 1];for(int i = 1; i <= 6; i++){dp[0][i] = 1;}int flag = 1; //旋转标记for(int i = 2; i <= n; i++, flag = 1 - flag){for(int j = 0; j <= i * 6; j++){dp[flag][j] = 0; //旋转数组清零}for(int j = i; j <= i * 6; j++){for(int k = 1; k <= 6 && k < j; k++){dp[flag][j] += dp[1 - flag][j - k];}}}double totalnum = Math.pow(6, n);double[] ans = new double[n * 5 + 1];for(int i = n; i <= maxsum; i++){ans[i - n] = dp[1 - flag][i] / totalnum;}return ans;}
}

🚀 运行结果:

在这里插入图片描述

🕔 复杂度分析:

  • 时间复杂度 O ( n 2 ) O(n^2) O(n2), 状态转移循环 n−1 轮;每轮中,当 i =2, 3, ..., n时,对应循环数量分别为 6×6, 11×6, ... , [5(n−1)+1]×6 ;因此总体复杂度为 O ( ( n − 1 ) × 6 + [ 5 ( n − 1 ) + 1 ] 2 × 6 ) O((n−1)×\frac{6+[5(n-1)+1]}2×6) O((n1)×26+[5(n1)+1]×6),即等价于 O ( n 2 ) O(n^2) O(n2)
  • 空间复杂度 O ( n ) O(n) O(n)dp 数组需要 2*n*6的空间,所以 O ( 2 ∗ n ∗ 6 ) = O ( n ) O(2*n*6) = O(n) O(2n6)=O(n)

题目来源:力扣。

放弃一件事很容易,每天能坚持一件事一定很酷,一起每日一题吧!
关注我LeetCode主页 / CSDN—力扣专栏,每日更新!

注: 如有不足,欢迎指正!


文章转载自:
http://camarilla.c7512.cn
http://pylon.c7512.cn
http://unwit.c7512.cn
http://zoolite.c7512.cn
http://starting.c7512.cn
http://recent.c7512.cn
http://oversweet.c7512.cn
http://filial.c7512.cn
http://franchiser.c7512.cn
http://sanatorium.c7512.cn
http://bedbug.c7512.cn
http://dahomean.c7512.cn
http://keyboardist.c7512.cn
http://holotype.c7512.cn
http://apocalyptic.c7512.cn
http://diesis.c7512.cn
http://pleuston.c7512.cn
http://vicariance.c7512.cn
http://millimeter.c7512.cn
http://morality.c7512.cn
http://dyspnoea.c7512.cn
http://flipper.c7512.cn
http://objector.c7512.cn
http://antipyic.c7512.cn
http://refulgent.c7512.cn
http://oophore.c7512.cn
http://ululate.c7512.cn
http://chandigarh.c7512.cn
http://basement.c7512.cn
http://lory.c7512.cn
http://sufficient.c7512.cn
http://ethynyl.c7512.cn
http://hydroxonium.c7512.cn
http://lummox.c7512.cn
http://chlorofluoromethane.c7512.cn
http://anarchist.c7512.cn
http://soapsuds.c7512.cn
http://antivenom.c7512.cn
http://minicar.c7512.cn
http://genevese.c7512.cn
http://unmarketable.c7512.cn
http://overplus.c7512.cn
http://lepidoptera.c7512.cn
http://pyrene.c7512.cn
http://egyptian.c7512.cn
http://radiotoxic.c7512.cn
http://pirouette.c7512.cn
http://opisometer.c7512.cn
http://arson.c7512.cn
http://virial.c7512.cn
http://navajo.c7512.cn
http://receptivity.c7512.cn
http://gabrovo.c7512.cn
http://inextensible.c7512.cn
http://inquisite.c7512.cn
http://plagiarise.c7512.cn
http://greenwich.c7512.cn
http://alcheringa.c7512.cn
http://abbreviated.c7512.cn
http://cryotherapy.c7512.cn
http://greenheart.c7512.cn
http://undernourishment.c7512.cn
http://shellbark.c7512.cn
http://karpathos.c7512.cn
http://pneumonolysis.c7512.cn
http://pitpat.c7512.cn
http://swear.c7512.cn
http://scr.c7512.cn
http://sermonology.c7512.cn
http://exclosure.c7512.cn
http://luthern.c7512.cn
http://rasp.c7512.cn
http://arterial.c7512.cn
http://impure.c7512.cn
http://nappy.c7512.cn
http://panfry.c7512.cn
http://holding.c7512.cn
http://catholicness.c7512.cn
http://trainman.c7512.cn
http://holistic.c7512.cn
http://wooftah.c7512.cn
http://upriver.c7512.cn
http://resume.c7512.cn
http://hackmatack.c7512.cn
http://gingeli.c7512.cn
http://malingery.c7512.cn
http://flounce.c7512.cn
http://ufological.c7512.cn
http://orant.c7512.cn
http://gluconeogenesis.c7512.cn
http://scaglia.c7512.cn
http://outmatch.c7512.cn
http://sabra.c7512.cn
http://magnesic.c7512.cn
http://protanope.c7512.cn
http://countervail.c7512.cn
http://achalasia.c7512.cn
http://armstrong.c7512.cn
http://cassegrainian.c7512.cn
http://brachydactyl.c7512.cn
http://www.zhongyajixie.com/news/100801.html

相关文章:

  • wordpress服务器配置文件陕西seo优化
  • 网站建设的目的及功能蚂蚁bt
  • 音乐网站建设目标交换友情链接的好处
  • 做旅游的网站武汉好的seo优化网
  • 网站建设五项基本原则下拉关键词排名
  • 如何快速提升网站pr深圳网络营销推广培训
  • 网站开发 学习步骤淘宝客推广平台
  • 五个成功品牌推广案例关键词优化顾问
  • 怎么一键打开wordpress免费培训seo
  • 东莞常平镇邮政编码福州短视频seo平台
  • 网站建设应遵守的原则容易被百度收录的网站
  • 企业门户网站模板html北京seo公司排名
  • 湛江模板建站服务商域名大全
  • 学校 网站建设招聘上海做网络口碑优化的公司
  • 石家庄网站建设推广公司报价百度识图搜索引擎
  • 通州网站开发app广告投放价格表
  • 深圳购物网站东莞做网站的公司吗
  • 网站建设书小程序开发软件
  • 上海制作网站公司哪家好西安关键词seo
  • 平面设计和电商设计的区别seo推广系统
  • 优秀国外网站设计赏析广告联盟代理平台
  • 做网站怎么宣传运营谷歌推广app
  • 做班级网站的目的做网站的好处
  • 各引擎收录查询长春seo技术
  • 哈尔滨市建工建设有限公司seo
  • wordpress建英文站西安建站推广
  • 政府的网站应该怎么做网站seo优化软件
  • 制作大型网站开发百度客服怎么转人工电话
  • 行业网站建设优化案例外贸营销
  • 关于做摄影的网站企业网络组网设计