QQ登录

只需一步,快速开始

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 1285|回复: 5

一道微软面试题

[复制链接]
发表于 2002-11-17 00:06:41 | 显示全部楼层 |阅读模式
从网上搜出来的,没有仔细的研究是不是答案正确,大家看看吧:

一道微软面试题:

5个强盗(A,B,C,D,E)分100个金币。他们设定了一个规则:从A开始给出分金币的提议,然后其余的强盗投赞同或反对票,如果反对票数大于或等于赞同票数,A就被杀掉,否则就按此提议分金币;如果A被杀了,接着就轮到B提议,然后同样按上述规则继续下去。假设每一个强盗都是绝顶聪明的,而且他们的所有行为(提议与投票)都是对自己最有利的(即能够在保命的前提下得最多的钱)。请问这100个金币是怎么分的? 每个人各拿多少?

答案:A要能活下来而又分得尽量多的金币,突破口就在于要认识到CD两人要么会投A的赞成票,要么会投B的赞成票,总归CD不会等到他们自己去提议,否则必死无疑(除非自己不分钱,但也可能会死,E可以总是投反对票),所以A只要给CD各自一个金币就可以了,因为CD清楚轮到B提议的时候就算B不给他们金币,他们也只能同意,但A不能不给CD金币,否则CD会等到B提议,毕竟这样多一次得钱的机会,即便B也不给他们,也没吃什么亏(总归还是没得到金币)。再来考虑E,由于轮到B提议的时候,CD总会投赞成票,所以E会一分钱都得不到,同CD一样的逻辑,A只需给E一块金币就可以了。到此,A已经拉拢了三个强盗,决议已经能够通过,最后就是最大化自身利益的时候,如何去最大化,当然就是不给B任何金币,因为此时B反对与否都是无关紧要的,所以最终答案就是:A-97块金币,B-0块金币,CDE各自一块金币。
发表于 2002-11-17 01:33:30 | 显示全部楼层
这个题我是倒过来考虑的。如果只剩下CDE,那么CD肯定会死。
如果剩下BCDE四个人,B全拿就可以了, 因为CD肯定会同意。轮到A的时候,A要得三张选票的话,就贿赂CDE一人一个金币就可以了。
回复

使用道具 举报

发表于 2002-11-18 12:24:46 | 显示全部楼层
微软便是:追求利益最大化!
回复

使用道具 举报

发表于 2004-3-4 05:17:47 | 显示全部楼层
我记得原题多2个条件1是多杀人且保命>多得金币>多杀人.另外自己可以参与投票


*当剩下D和E时,D必死.所以当轮C分配时D为保命一定同意.这时C会把100个都分给自己.
考虑到上面的情况(每一个强盗都是绝顶聪明的),当轮到B分配时,B会给D和E各一个其余的98个留给自己.DE考虑到上面的情况也必然同意,否则由C分配的时候他们一个也拿不到.
考虑到上述两种情况.A分配时.会分给C一个.C必然同意,否则由B分的时候他一个也拿不到.分D或E当中的一个人两个金币.D或E考虑到A死后由B来分配时他只能得到一个金币.所以也会同意.3>2,所以A的这个分配方案被采取.

理解了这个答案后你会发现.题目是矛盾的."假设每一个强盗都是绝顶聪明的"成立的话就不会有这个规则.

记得有个同样经典的题目是:12个小球中当中有一个质量不同.现只有一个天平(没有砝码和刻度),要求用天平称三次把那个质量不同的球找出来.How to?
回复

使用道具 举报

发表于 2004-3-4 10:24:17 | 显示全部楼层
这原本是一道经典的最佳决策题目--海盗分金
原题是500个海盗分100块金子。楼主叙述的这种问法是吧海盗分金问题大大简化了。
下面是海盗分金原题:

海盗的难题
Ian Stewart
  
    数学的逻辑有时会导致看来十分怪异的结论。一般的规则是,如果逻辑
推理没有漏洞, 那么结论就必定站得住脚,即使它与你的直觉矛盾。 1998
年9月,加利福尼亚州帕洛阿 尔托的Stephen M. Omohundro寄给我一道难题,
它恰好就属于这一类。这难题已经流传 了至少十年,但是Omohundro对它作
了改动,使它的逻辑问题变得分外复杂了。
  
    先来看看此难题原先的形状。10名海盗抢得了窖藏的100块金子,并打算
瓜分这些战利 品。这是一些讲民主的海盗(当然是他们自己特有的民主),
他们的习惯是按下面的方式进行分配:最厉害的一名海盗提出分配方案,然
后所有的海盗(包括提出方案者本人)就此方案进行表决。如果50%或更多的
海盗赞同此方案,此方案就获得通过并据此分配战利品。否则提出方案的海
盗将被扔到海里,然后下提名最厉害的海盗又重复上述过程。
  
    所有的海盗都乐于看到他们的一位同伙被扔进海里,不过,如果让他们
选择的话,他们还是宁可得一笔现金。他们当然也不愿意自己被扔到海里。
所有的海盗都是有理性的,而且知道其他的海盗也是有理性的。此外,没有
两名海盗是同等厉害的——这些海盗按照完全由上到下的等级排好了座次,
并且每个人都清楚自己和其他所有人的等级。这些金块不能再分,也不允许
几名海盗共有金块,因为任何海盗都不相信他的同伙会遵守关于共享金块的
安排。这是一伙每人都只为自己打算的海盗。
    最凶的一名海盗应当提出什么样的分配方案才能使他获得最多的金子呢?
  
    为方便起见,我们按照这些海盗 那优 程度来给他们编号。最怯懦的海
盗为1号海盗,次怯懦的海盗为2号海盗,如此类推。这样最厉害的海盗就应
当得到最大的编号,而方案的提出就将倒过来从上至下地进行。
  
    分析所有这类策略游戏的奥妙就在于应当从结尾出发倒推回去。游戏结
  
束时,你容易知道何种决策有利而何种决策不利。确定了这一点后,你就可
以把它用到倒数第2次决策上,如此类推。如果从游戏的开头出发进行分析,
那是走不了多远的。其原因在于,所有的战略决策都是要确定:“如果我这
样做,那么下一个人会怎样做?” 因此在你以下海盗所做的决定对你来说是
重要的,而在你之前的海盗所做的决定并不重要,因为你反正对这些决定也
无能为力了。
  
    记住了这一点,就可以知道我们的出发点应当是游戏进行到只剩两名海
盗——即1号和2号——的时候。这时最厉害的海盗是2号,而他的最佳分配方
案是一目了然的:100块金子全归他一人所有,1号海盗什么也得不到。由于
他自己肯定为这个方案投赞成票,这样就占了总数的50%,因此方案获得通过。
现在加上3号海盗。1号海盗知道,如果3号的方案被否决,那么最后将只剩2
个海盗,而1号将肯定一无所获——此外,3号也明白1号了解这一形势。因此,
只要3号的分配方案,给1号一点甜头使他不至于空手而归,那么不论3号提出
什么样的分配方案,1号都将投赞成票。因此3号需要分出尽可能少的一点金子
来贿赂1号海盗,这样就有了下面的分配方案: 3号海盗分得99块金子,2号海
盗一无所获,1号海盗得1块金子。4号海盗的策略也差不多。他需要有50%的支
持票,因此同3号一样也需再找一人做同党。他可以给同党的最低贿赂是1块金
子,而他可以用这块金子来收买2号海盗。因为如果4号被否决而3号得以通过,
则2号将一文不名。因此,4号的分配方案应是:99块金子归自己,3号一块也
得不到,2号得1块金子,1号也是一块也得不到。5号海盗的策略稍有不同。他
需要收买另两名海盗,因此至少得用2块金子来贿赂,才能使自己的方案得到
采纳。他的分配方案应该是:98块金子归自己,1块金子给3号,1块金子给1号。

  
    这一分析过程可以照着上述思路继续进行下去。每个分配方案都是唯一确
定的,它可以使提出该方案的海盗获得尽可能多的金子,同时又保证该方案肯
定能通过。照这一模式进行下去,10号海盗提出的方案将是96块金子归他所有,

其他编号为偶数的海盗各得1 块金子,而编号为奇数的海盗则什么也得不到。
这就解决了10名海盗的分配难题。
  
    Omohundro的贡献是他把这一问题扩大到有500名海盗的情形,即500名海
盗瓜分100块金子。显然,类似的规律依然成立——至少是在一定范围内成立。
事实上,前面所述的规律直到第200号海盗都成立。 200号海盗的方案将是:
从1到199号的所有奇数号的海盗都将一无所获,而从2到198号的所有偶数号
海盗将各得1块金子,剩下的1块金子归200号海盗自己所有。
  
    乍看起来,这一论证方法到200号之后将不再适用了,因为201号拿不出更
多的金子来收买其他海盗。但是即使分不到金子,201号至少还希望自己不会
被扔进海里,因此他可以这样分配:给1到199号的所有奇数号海盗每人1块金
子,自己一块也不要。202号海盗同样别无选择,只能一块金子都不要了——
他必须把这100块金子全部用来收买100名海盗,而且这100名海盗还必须是那
些按照201号方案将一无所获的人。
    由于这样的海盗有101名,因此202号的方案将不再是唯一的——贿赂方案
有101种。203号海盗必须获得102张赞成票,但他显然没有足够的金子去收买
101名同伙。因此,无论提出什么样的分配方案,他都注定会被扔到海里去喂
鱼。不过,尽管203号命中注定死路一条,但并不是说他在游戏进程中不起任
何作用。相反,204号现在知道,203号为了能保住性命,就必须避免由他自
己来提出分配方案这么一种局面,所以无论204号海盗提出什么样的方案,203
号都一定会投赞成票。这样204号海盗总算 男 拣到一条命:他可以得到他自
己的1票、203号的1票、以及另外100名收买的海盗的赞成票,刚好达到保命所
需的50%。获得金子的海盗,必属于根据202号方案肯定将一无所获的那101名
海盗之列。
    205号海盗的命运又如何呢?他可没有这样走运了。他不能指望203号和
204号支持他的方案,因为如果他们投票反对205号方案,就可以 以掷 祸地
看到205号被扔到海里去喂鱼,而他们自己的性命却仍然能够保全。这样,无
论205号海盗提出什么方案都必死无疑。
    206号海盗也是如此——他肯定可以得到205号的支持,但这不足以救他
一命。类似地,207号海盗需要104张赞成票——除了他收买的100张赞成票以
及他自己的1张赞成票之外,他还需3张赞成票才能免于一死。他可以获得205
号和206号的支持,但还差一张票却是无论如何也弄不到了,因此207号海盗
的命运也是下海喂鱼。
    208号又时来运转了。他需要104张赞成票,而205、206、207号都会支持
他,加上他自己一票及收买的100票,他得以过关保命。获得他贿赂的必属于
那些根据204号方案肯定将一无所获的人(候选人包括2到200号中所有偶数号
的海盗、以及201、203、204 号)。
  
    现在可以看出一条新的、此后将一直有效的规律:那些方案能过关的海盗

(他们的分配方案全都是把金子用来收买100名同伙而自己一点都得不到)相
隔的距离越来越远,而在他们之间的海盗则无论提什么样的方案都会被扔进海
里——因此为了保命,他们必会投票支持比他们厉害的海盗提出的任何分配方
案。得以避免葬身鱼腹的海盗包括201、202、204、208、216、232、264、328、

456号,即其号码等于200加2的某一方幂的海盗。
  
    现在我们来看看哪些海盗是获得贿赂的幸运儿。分配贿赂的方法是不唯一
的,其中一种方法是让201号海盗把贿赂分给1到199号的所有奇数编号的海盗,

让202号分给2到200号的所有偶数编号的海盗,然后是让204号贿赂奇数编号的
海盗,208号贿赂偶数编号的海盗,如此类推,也就是轮流贿赂奇数编号和偶
数编号的海盗。
  
    结论是:当500名海盗运用最优策略来瓜分金子时,头44名海盗必死无疑,
而456号海盗则给从1到199号中所有奇数编号的海盗每人分1块金子,问题就解
决了。由于这些海盗所实行的那种民主制度,他们的事情就搞成了最厉害的一
批海盗多半都是下海喂鱼,不过有时他们也会觉得自己很幸运——虽然分不到
抢来的金子,但总可以免于一死。只有最怯懦的200名海盗有可能分得一份脏
物,而他们之中又只有一半的人能真正得到一块金子,的确是怯懦者继承财富。

===================================
几句题外话:
从这道题目来看,似乎说明:民主的原则->怯懦者继承财富
当然,绝对理性是一种只有在数学题中才能出现的情况,不过数学分析的结果至少能说名一种趋势:民主->弱者得利
回复

使用道具 举报

发表于 2004-3-9 10:06:39 | 显示全部楼层
精彩
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

GMT+8, 2024-11-8 21:02 , Processed in 0.043282 second(s), 16 queries .

© 2021 Powered by Discuz! X3.5.

快速回复 返回顶部 返回列表