- n个骰子的点数
- 题目
- 解题思路
n个骰子的点数
题目
把 n 个骰子扔在地上,所有骰子朝上一面的和为 s,输入 n,打印 s 所有可能值的概率
解题思路
- 首先考虑一个骰子的情况,那么有 1~6 出现的次数均为 1
- 再增加一个骰子时,由于各个点数出现的概率一致。用 $$f(n,s)=f(n-1,s-1)+f(n-1,s-2)+f(n-1,s-3)+f(n-1,s-4)+f(n-1,s-5)+f(n-1,s-6)$$
- 使用两个数组循环求解
public void SumOfNDice(int n) {if (n < 1) {return;}int[][] nums = new int[2][n * 6 + 1];int flag = 0;//初始化第一个骰子各总和出现的次数int maxLen = nums[0].length;for (int i = 1; i < maxLen; i++) {nums[flag][i] = 1;}for (int i = 2; i <= n; i++) {int newFlag = flag ^ 0x01;Arrays.fill(nums[newFlag], 0);for (int j = i; j < maxLen; j++) {int sum = 0;for (int k = 1; k <= 6 && (j - k >= 0); k++) {sum += nums[flag][j - k];}nums[newFlag][j] = sum;}flag = newFlag;}//debug outSystem.out.println(Arrays.toString(nums[flag]));int sum = 0;for (int i : nums[flag]) {sum += i;}for (int i = 0; i < nums[flag].length; i++) {System.out.println(i + ":" + nums[flag][i] * 1.0 / sum);}}
