第一种思路是,每一个骰子的点数从最小到最大,如果为1-6,那么全部的骰子从最小1開始,我们如果一种从左向右的排列,右边的最低,索引从最低開始,推断和的情况。

def setTo1(dices, start, end):
for i in range(start, end):
dices[i] = 1 def probability(n, s, dmax = 6, dmin = 1):
if s < n * dmin or s > n * dmax : return 0
dices = [1] * n
i = n - 1
total = 0 while i >= 0:
curSum = sum(dices)
if curSum == s:
print dices
total += 1
# find first one that can +1
for j in range(i, -1, -1):
if dices[j] < dmax and s - sum(dices[0:j+1]) >= n - j*dmin:
dices[j] += 1
setTo1(dices, j + 1, n)
i = n - 1
break
else:
i -= 1
elif curSum < s:
if dices[i] < dmax:
dices[i] += 1
i = n - 1
else:
i -= 1 print "total = {0}, prob = {1}%".format(total, total*100/dmax**n)
return total

若当前和小于s,则检验当前索引处的骰子是否能添加�1,若能,则添加�,否则查看其前面的是否能添加�。若相等,那么我们统计信息后,要变化当前的情形,以便处理下一种情况,由于 索引是从低位開始到当前位的,所以我们从当前索引開始,向前找能继续添加�的骰子,这里的推断标准是当前骰子的点数小于最小值,并且要保证其后的骰子的最小值为1,比方 1,4,1, s = 6, 当前索引指向4, 这里的4尽管小于最大点数6, 但若其再加一,第三个骰子就的为0,这不符合要求。若找到能够加一的骰子,那就将该骰子点数加1, 将其后的骰子都置为1,索引回到最后,開始又一次加起。如:1,1,6,s
= 8, 索引指向6, 改动后为1,2,1,索引指向最后的1,。若没有找到能够再添加�的骰子,那么就结束。如6,1,1,s = 8。

事实上若给定的n不大的话,我们能够设一个n位整数,从n个1開始,逐次加一,来推断各个位的和是否满足要求,直到达到最大值,n个6。

这个问题事实上动态规划的特点非常明显。

'''
@ state function: dp[i, j]: the total cases of sum = j, composed by i dices
@ state tranfor function: dp[i, j] = sum(dp[i - 1, j - k]) for k in [dmin, dmax]
@ dp[i, j] = 0, j > i * dmax or j < i * dmin
@ init condition: dp[1, k] = 1, for k in [dmin, dmax], dp[1, k] = 0, for other k
'''
def dp_probability(n, s, dmax = 6, dmin = 1):
if s < n * dmin or s > n * dmax :
return 0
dp1 = [0] * (n * dmax + 1) #init dp[1, :]
for i in range(1, dmax + 1):
dp1[i] = 1
# i: the number of dices
for i in range(2, n + 1):
dp2 = [0] * (n * dmax + 1)
# j: range of i dices
for j in range(dmin * i, dmax * i + 1):
# k: range of new added dice
for k in range(dmin, dmax + 1):
if j > k :
dp2[j] += dp1[j - k]
print dp2
dp1 = dp2
print "total = {0}, prob = {1}%".format(dp2[s], dp2[s]*100/dmax**n)
return dp2[s]

【剑指offer】面试题43:n个骰子的点数的更多相关文章

  1. 剑指offer 面试题43. 1~n整数中1出现的次数

    leetcode上也见过一样的题,当时不会做 看了一下解法是纯数学解法就没看,结果剑指offer上也出现了这道题,那还是认真看下吧 对于数字abcde,如果第一位是1,比如12345,即计算f(123 ...

  2. 剑指offer面试题43:n个筛子的点数

    题目描述: 把n个筛子扔在地上,所有筛子朝上的一面点数之和为s,输入n,打印出s的所有可能的值出线的概率. 书上给了两种解法,第一种递归的方法由于代码太乱,没有看懂=.= 第二种方法很巧妙,lz已经根 ...

  3. 剑指Offer面试题43(Java版):n个骰子的点数

    题目:把n个骰子仍在地上.全部骰子朝上一面的点数之和为s,输入n,打印出s的全部可能的值出现的概率. 解法一:基于递归求骰子的点数,时间效率不够高 如今我们考虑怎样统计每个点数出现的次数. 要向求出n ...

  4. 剑指Offer:面试题15——链表中倒数第k个结点(java实现)

    问题描述 输入一个链表,输出该链表中倒数第k个结点.(尾结点是倒数第一个) 结点定义如下: public class ListNode { int val; ListNode next = null; ...

  5. 剑指offer面试题3 二维数组中的查找(c)

    剑指offer面试题三:

  6. 剑指Offer——笔试题+知识点总结

    剑指Offer--笔试题+知识点总结 情景回顾 时间:2016.9.23 12:00-14:00 19:00-21:00 地点:山东省网络环境智能计算技术重点实验室 事件:笔试 注意事项:要有大局观, ...

  7. C++版 - 剑指offer之面试题37:两个链表的第一个公共结点[LeetCode 160] 解题报告

    剑指offer之面试题37 两个链表的第一个公共结点 提交网址: http://www.nowcoder.com/practice/6ab1d9a29e88450685099d45c9e31e46?t ...

  8. C++版 - 剑指offer 面试题23:从上往下打印二叉树(二叉树的层次遍历BFS) 题解

    剑指offer  面试题23:从上往下打印二叉树 参与人数:4853  时间限制:1秒  空间限制:32768K 提交网址: http://www.nowcoder.com/practice/7fe2 ...

  9. C++版 - 剑指offer 面试题39:判断平衡二叉树(LeetCode 110. Balanced Binary Tree) 题解

    剑指offer 面试题39:判断平衡二叉树 提交网址:  http://www.nowcoder.com/practice/8b3b95850edb4115918ecebdf1b4d222?tpId= ...

  10. Leetcode - 剑指offer 面试题29:数组中出现次数超过一半的数字及其变形(腾讯2015秋招 编程题4)

    剑指offer 面试题29:数组中出现次数超过一半的数字 提交网址: http://www.nowcoder.com/practice/e8a1b01a2df14cb2b228b30ee6a92163 ...

随机推荐

  1. BZOJ 1812: [Ioi2005]riv( 树形dp )

    树背包, 左儿子右兄弟来表示树, dp(x, y, z)表示结点x, x的子树及x的部分兄弟共建y个伐木场, 离x最近的伐木场是z时的最小代价. 时间复杂度O(N^2*K^2) ----------- ...

  2. day3_python学习笔记_chapter5_数字

    1. 整形的表示范围-2^32~2^32 - 1 : 长整形表示:aLong = 99999L 2. 复数的属性, num.real,该复数的实部, num.imag,该复数的虚部.num.conju ...

  3. js基础参数获取

    1 获取浏览器中url中的参数,会自动把问号"?"去掉 function getParamsFromHref() { //调试用 var wyl_ = window.locatio ...

  4. 安卓2D游戏开发设置

    http://www.cnblogs.com/xiaominghimi/archive/2010/12/23/1921402.html

  5. Java I/O theory in system level

    参考文章: JAVA NIO之浅谈内存映射文件原理与DirectMemory Java NIO 2.0 : Memory-Mapped Files | MappedByteBuffer Tutoria ...

  6. Windows 系统消息范围和前缀,以及消息大全

    Windows系统定义的消息类别消息标识符前缀 消息分类ABM 应用桌面工具栏消息BM 按钮控件消息CB 组合框控件消息CBEM 扩展组合框控件消息CDM 通用对话框消息DBT 设备消息DL 拖曳列表 ...

  7. mysql远程登录权限

    GRANT ALL PRIVILEGES ON *.* TO 'root'@'%'WITH GRANT OPTION; FLUSH PRIVILEGES;

  8. clistctrl 虚拟列表

    一.什么是虚拟列表控件 虚拟列表控件是指带有LVS_OWNERDATA风格的列表控件.. 二.为什么使用虚拟列表控件 我们知道,通常使用列表控件CListCtrl,需要调用InsertItem把要显示 ...

  9. 化简复杂逻辑,编写紧凑的if条件语句(二):依据if子句顺序化简条件

    <化简复杂逻辑,编写紧凑的if条件语句>已经得出了跳.等.飞.异常的各自条件,方便起见这里重新贴一下. 立即跃迁:!a && b && d 等待跃迁:!a ...

  10. block 解析 - 内存

    block结构体相应的也有一个成员引用,这样会增加对局部变量的 _para1引用,在Block销毁的时候引用就释放掉了 我们了解到了用__block修饰的变量,可以在block内部修改,__block ...