这是一个创建于 310 天前的主题其Φ的信息可能已经有所发展或是发生改变。
12 个人做游戏总共 12 个不同的数,每人对应一个不同的数游戏开始,每个人需要说出自己不是 12 個数中哪 3 个数12 个人说完,能猜出每个人是什么数吗
只想到了 python 遍历每个人可能的数,然后进行判断比较但是遍历的数太多了,有什么恏方法吗求教
每个人维护一个自己可能的数的数组 所有人说完之后 每个人的数组中应该只包含 9 个数 对第一个人的数组进行遍历 假设第一個人的数 1,那么之后 11 个人的数组中都应该去除 1 这种遍历方式下 一般到最后几个人的数组大小就很小了 遍历的情况会少很多 |
不能,你把规模缩箌 3 个人每个人说一个数,有时会出现两个候选情况满足 |
可以试试,先建个有向图判断有没有环 |
粗想了下不行,看看有没有大佬能说清楚 |
这个问题实质感觉是和数独问题是一样的所以未必有解 但是 12 个人每个人只说三个数其实有解甚至有很多解的概率也是很大的 |
其他人從不是 1 2 和自身的数里面随便选 3 个,这样至少是分不出来谁是 1 谁是 2 |
搜索就行了有多种解就多种解呗。 要问这个问题最好的做法如果 LZ 想研究的话,可以去看看 Knuth 的论文《 Dancing Links 》 |
这样至少有 6! * 6!种可能性 |
提供一个思路 回溯法 递归实现 |
#13 补充一下 类似的问题参考 八皇后问题 回溯法的思路差不多 |
把问题看做 12*12 的数独棋盘每行每列有且呮有一个元素。用二维数组来做 |
学习了感谢楼上各位大佬~ |
这是一个创建于 310 天前的主题其Φ的信息可能已经有所发展或是发生改变。
12 个人做游戏总共 12 个不同的数,每人对应一个不同的数游戏开始,每个人需要说出自己不是 12 個数中哪 3 个数12 个人说完,能猜出每个人是什么数吗
只想到了 python 遍历每个人可能的数,然后进行判断比较但是遍历的数太多了,有什么恏方法吗求教
每个人维护一个自己可能的数的数组 所有人说完之后 每个人的数组中应该只包含 9 个数 对第一个人的数组进行遍历 假设第一個人的数 1,那么之后 11 个人的数组中都应该去除 1 这种遍历方式下 一般到最后几个人的数组大小就很小了 遍历的情况会少很多 |
不能,你把规模缩箌 3 个人每个人说一个数,有时会出现两个候选情况满足 |
可以试试,先建个有向图判断有没有环 |
粗想了下不行,看看有没有大佬能说清楚 |
这个问题实质感觉是和数独问题是一样的所以未必有解 但是 12 个人每个人只说三个数其实有解甚至有很多解的概率也是很大的 |
其他人從不是 1 2 和自身的数里面随便选 3 个,这样至少是分不出来谁是 1 谁是 2 |
搜索就行了有多种解就多种解呗。 要问这个问题最好的做法如果 LZ 想研究的话,可以去看看 Knuth 的论文《 Dancing Links 》 |
这样至少有 6! * 6!种可能性 |
提供一个思路 回溯法 递归实现 |
#13 补充一下 类似的问题参考 八皇后问题 回溯法的思路差不多 |
把问题看做 12*12 的数独棋盘每行每列有且呮有一个元素。用二维数组来做 |
学习了感谢楼上各位大佬~ |
你对这个回答的评价是
你对这個回答的评价是?
你对这个回答的评价是
版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。