每日一题--n个骰子的点数
来源:互联网 发布:windows whistler2542 编辑:程序博客网 时间:2024/06/05 20:24
基于循环求骰子总数:用两个数组来存储骰子点数出现的每一个总和出现的次数:
第一个数组中的第n个数字代表骰子点数和为n出现的次数
第二个数组的第n个数字设为前一个数组对应的第n-1,第n-2,第n-3,n-4,n-5,n-6之和
解释:一次循环中第一个数组中的第n个数字代表骰子点数和为n出现的次数
下一次循环,我们加上一个新的骰子,此时和为n的骰子出现的次数应该为上一次循环中骰子点数和为n-1,n-1……n-6的次数总和(第二个数组的作用)
在一轮循环中,一个数组的第n项等于另一数组的前n-1,n-2,n-3,……n-6项,在下一轮循环中,交换这两个数组,通过改变flag来实现,再次循环
代码:
package six;/**问题描述:n个骰子朝上一面和为s,输入n,打印出s的所有可能的值出现的概率 * 统计出每一个点数出现的次数/6^n ,就能求出每个点数的概率 * Created by lxq on 2017/9/17. */public class Problem1 { public void printProbability(int number){ if(number<1) return; int maxValue = 6; int Probabilities[][] = new int[2][]; //第一个数组:第n个数字代表骰子和为n出现的次数 //暂存 Probabilities[0] = new int[maxValue*number+1]; //第二个数组:加上一个骰子后 // 第n个数字设为前一个数组对应的第n-1,第n-2,第n-3,n-4,n-5,n-6之和 Probabilities[1] = new int[maxValue*number+1]; int flag = 0; //一个骰子 for(int i=1;i<=maxValue;i++){ Probabilities[flag][i] = 1; } //每增加一个骰子,k代表骰子的数目 for(int k=2;k<=number;k++){ //骰子点数最小为k,所以数组前k项为0 for(int i=0;i<k;i++){ Probabilities[1-flag][i] = 0; } for(int i=k;i<=maxValue*k;i++){ Probabilities[1-flag][i] = 0; //初始化 //这里 j<=i&&j<maxValue最为关键 for(int j=1;j<=i&&j<=maxValue;j++) //……[0][n-6] Probabilities[1-flag][i] += Probabilities[flag][i-j]; } flag = 1-flag; } double total = Math.pow(maxValue,number); for(int i=number;i<=maxValue*number;i++){ double ratio = (double) Probabilities[flag][i]/total; System.out.println(i+""); System.out.println(ratio); } }}
阅读全文
0 0
- 每日一题--n个骰子的点数
- n个骰子的点数
- n 个骰子的点数
- n个骰子的点数
- n个骰子的点数
- n个骰子的点数
- N个骰子的点数
- n个骰子的点数
- n个骰子的点数
- n个骰子的点数
- n个骰子的点数
- n个骰子的点数
- n个骰子的点数
- n个骰子的点数
- n个骰子的点数
- n个骰子的点数
- n个骰子的点数
- N个骰子的点数
- 2018科大讯飞校招---足球队
- pat1008
- Spring知识整理(学习资料)
- MyBatis的flushCache和useCache的使用
- 2018科大讯飞校招---争吵
- 每日一题--n个骰子的点数
- [笔记] 次小生成树
- 网络DHCP基本实验
- Numpy基本操作
- leetcode---decode-ways--dp
- Mysql性能优化
- Guava Immutable和JDK Collections.unmodifiableXXX不可变集合比较
- 商汤2017笔试编程题——绘制函数图像
- 多线程程序启动多少线程比较好