您的位置:首页 > 其它

【每天一道算法题】国王和囚犯

2013-01-11 00:08 239 查看
上一题真心优化不出了的说。。。TAT。。。

话说还是最喜欢今天这样的趣味智力题,虽然和算法也没什么大关系哒,很适合消磨时间就是了~

题目来了~

国王招来100个囚犯,对他们说:你们犯的是死罪,但我给你们一次求生的机会。15分钟以后,你们将被关进一个有100间隔离牢房的监狱里,每人一间牢房,都与外界隔绝,什么也听不见看不到,连时间都没法计算,无法获得外界的任何信息。

这所监狱有一个院子,每天只少随机(注意是完全随机)打开一间牢房的门,让一个囚犯到院子里来放风。院子里有一盏灯,放风的囚犯可以控制它的开关,将它打开或是关闭。除囚犯之外,其他人都不会去碰开关。这盏灯会永远有充足的能源供应,灯泡和电路不会出故障。

除了开关这盏灯,放风的囚犯放风时留下的任何其它痕迹都会在夜晚被清除干净(包括在灯上作的任何记号)。牢房是完全封闭的,院子里的灯光在牢房里看不到。只有放风到院子里的人才能看到。

好了现在我向你们提出一个要求,只要你们做到了,就可以全部获得释放:

给你们15分钟商量你们的方案。15分钟以后,你们将被关进我刚才说的那个监狱,永远无法再交流,被关若干天后,你们中间如果任何一个人能够向我证明你们每个人都至少放风了一次,我就把你们放了,不然永远别想再出来。

好吧!这样吧,如果你们有谁现在可以告诉我这个方法,也就是能够证明你们每人至少放风一次的方法,我马上放掉你们!

其中一个囚犯想了几分钟,回答了这个问题,国王听后,如自己所说的把他们全部给放了。请问那个囚犯是用什么方法证明的?

我一定是要被杀掉的囚犯啦。。。前两天想着想着就睡着了,第三天才想出来

但是想出来的却是很耗费时间的方法,不知有没有更好的呢?

就是选定一个人专门关灯,其他人每人要且只要开一次灯,仅当放风时灯是关着的而且自己从来开过灯时,打开灯,选定的人看到灯开着就关灯。

关满99次就说明其他人都放风过啦。

我想这个方法等大家放出来前都老了吧。。。>。<
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: