前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >每日一题 | 拜占庭将军问题

每日一题 | 拜占庭将军问题

作者头像
TechFlow-承志
发布2020-08-10 17:59:54
9350
发布2020-08-10 17:59:54
举报
文章被收录于专栏:TechFlowTechFlow

昨日问题

每日一题 | 一百个囚犯与一百个抽屉问题

这道题来源于读者投稿,解法来源于知乎。

很显然,每个囚犯最多打开50个抽屉,抽中自己号码的概率是1/2。但是我们有100个囚犯,这100个囚犯都找到自己号码的概率就是2的一百次方分之一。咱们也不必要去计算这个值,显然是一个天文数字。

那么有没有更好的策略呢?

其实是有的,并且非常巧妙,巧妙到几乎很难想到。策略是对于囚犯i,他首先打开i号抽屉,如果i号抽屉当中就是i,显然他成功找到了。假设抽屉当中是号码j,那么他继续打开j号抽屉,重复上述过程,直到找到了号码i或者是用完了50次机会。

比如在这个例子当中,所有人都可以在用完机会之前找到自己的号码。

那么这种操作的原理是什么?

原理就是找环,我们把问题进行抽象和转化。首先我们把抽屉上的号码看成是起始点,把抽屉里的卡片号码看成是终点。这样我们就连出了一条有向边,比如1号抽屉里是7号卡片,我们就得到了一条从1指向7的边,一共有100个抽屉100张卡片,所以就有100个点和100条边。

再加上每个点的入度和出度都是1,那么根据图论中点和边的性质,我们可以确定,每一个点都在环当中。那么剩下的就很好办了,环是确定的,不确定的就是环的大小。

对于一个确定的点i来说,它所在的环长度可能是1也可能是100。只要大于50,我们就无法找到解了。

那么这个概率应该怎么算呢?

首先,可以确定的是如果存在长度大于50的环,这个环一定只有1个。我们假设它的长度是L,那么,这个环的构成情况一共有C(100, L)种,这里的C表示组合数。对于每一种组合来说,一共有(L-1)!种排列,因为是一个环,所以不是L!。

这个环之外的元素有100-L个,它们的排列有(100 - L)!种。对于每一个L都有C(100, L) * (L-1)! * (100 - L)!=100!/L种情况。而100个数的总排列是100!,所以我们可以得到所有囚犯都猜对的概率是:

P = 1 - \frac{1}{100!} \sum_{i=51}^{100} \frac{100!}{i}= 1 - (\frac{1}{51} + \frac{1}{52}\cdots +\frac{1}{100}) \approx 0.31183

这里的计算看起来复杂,其实用到的只是小学的奥数排列组合的知识。不管怎么说,从结果上来看,这个概率显然比瞎猜要大得多的多了。

今日问题

拜占庭将军问题

拜占庭帝国为了征讨一座城堡派出了7个将军各自率领一个队伍,这个城堡非常坚固,必须要有一半以上的将军一起进攻才可以获胜,否则将会失败。由于科技落后,将军之间只能通过传令兵进行通信。

将军之间约定各自发出是否进攻的投票,如果收到进攻的意见超过半数则发起进攻。但由于7个将军当中混入了2个叛徒,叛徒会发出虚假的指令,比如向决定进攻的将军发送进攻,向想要撤退的将军发出撤退。比如3个忠诚的将军下令进攻,2个将军下令撤退,这时两个叛徒向3个忠诚的将军发送进攻,向2个想要撤回的将军发送撤退,这样将会导致实际进攻的将军只有3个,这会导致战争的失败。

假设现在将军们已经发现了叛徒的存在但不知道是哪两个将军是叛徒,忠诚的将军们应该采用什么样的方法才可以保证做出的决策不被叛徒影响?

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-08-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Coder梁 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 昨日问题
  • 每日一题 | 一百个囚犯与一百个抽屉问题
  • 今日问题
    • 拜占庭将军问题
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档