囚犯活命问题

问题描述:5个囚犯,分别按照1-5号在装有100颗绿豆的麻袋抓绿豆,规定每人至少抓一颗,而抓得最多和最少的人将被处死,而且,他们之间不能交流,但在抓的时候,可以摸出剩下的豆子数。问他们中谁的存活几率最大?提示:

1,他们都是很聪明的人
2,他们的原则是先求保命,再去多杀人
3,100颗不必都分完
4,若有重复的情况,则也算最大或最小,一并处死
解答:
     100个豆子5人平分,每人20个,所以我们可以确定不会有人拿20以上,否则他必死无疑。我们从后往前分析:5号想不死就必须不是最大或者最小,那么他肯定会选择前4个人的平均数,同理,4号也会选择前3个人的平均数,3号会拿前两个人的平均数。
现在我们分析1号和2号:
     先说2号:2号知道后面3个人肯定会选取平均数,所以2号肯定是与1号相等,或者相差1。
     现在讨论1号:1号肯定知道后面人的想法,如果让他们拿平均数,那么自己必死,所以1号肯定想办法不让5号拿到平均数。这样5人的平均数大于20,所以1号要拿的个数大于或等于20个。如果拿20以上,1号必死,且2,3,4可以保命,所以1只能拿20颗。
     然后同样2不能拿21颗,所以他只能拿20或者19颗。那19颗的结果就是(20,19,x,y,z)根据条件,不可能牺牲自己去救人,所以19<=x,y,z<=20,不管何种情况,大家全部会死。
     拿20颗的结果就是(20,20,20,20,20),同样,大家都会死掉。
     1号选择20颗符合多杀人原则,如果1号不考虑多杀人原则而选择少于20颗的话,结果也是一样会死掉。(x,x+1,a,b,c)(x<=a,b,c<=x+1),(x,x,x,x,x),(x,x-1,a,b,c)(x-1<=a,b,c<=x),上述情况所有人都会死掉。能保命就保命,不能保命就多杀人。
      所以结论是,5个人都得死。
(博弈论问题,和海盗分金类似)

转载于:https://www.cnblogs.com/ltang/archive/2010/10/13/1861141.html

百囚问题是一个经典的合作与背叛问题,也被称为囚徒困境。在百囚问题中,有一百个罪犯在独立审讯的情况下,他们被指控犯有某项罪行,并面临着不同的刑罚。每个囚犯可以选择合作或背叛其他囚犯。 如果一个囚犯选择合作,而其他囚犯也选择合作,那么每个人都将得到一个较轻的刑罚。如果一个囚犯选择背叛,而其他囚犯选择合作,那么背叛者会获得较轻的刑罚,而其他合作者会受到更严重的刑罚。如果所有囚犯都选择背叛,那么每个人都将获得较严重的刑罚。 要用Java实现百囚问题,可以通过编写一个囚犯类和一个审讯类来模拟该过程。囚犯类可以包含一个选择合作或背叛的方法,而审讯类可以用于模拟所有囚犯的选择和计算刑罚。 首先,创建一个囚犯类: ``` public class Prisoner { private boolean cooperate; public Prisoner(boolean cooperate) { this.cooperate = cooperate; } public boolean chooseCooperate() { return cooperate; } } ``` 然后,创建一个审讯类: ``` public class Trial { private Prisoner[] prisoners; private int[] punishments; public Trial() { prisoners = new Prisoner[100]; punishments = new int[100]; // 初始化囚犯和刑罚 for (int i = 0; i < prisoners.length; i++) { boolean cooperate = Math.random() < 0.5; prisoners[i] = new Prisoner(cooperate); punishments[i] = i; } } public void run() { for (int i = 0; i < prisoners.length; i++) { for (int j = 0; j < prisoners.length; j++) { if (i != j) { boolean cooperateI = prisoners[i].chooseCooperate(); boolean cooperateJ = prisoners[j].chooseCooperate(); if (cooperateI && cooperateJ) { punishments[i] -= 1; punishments[j] -= 1; } else if (!cooperateI && cooperateJ) { punishments[i] -= 2; punishments[j] += 2; } else if (cooperateI && !cooperateJ) { punishments[i] += 2; punishments[j] -= 2; } else { punishments[i] += 1; punishments[j] += 1; } } } } // 输出每个囚犯的刑罚 for (int i = 0; i < prisoners.length; i++) { System.out.println("囚犯" + (i + 1) + "的刑罚:" + punishments[i]); } } public static void main(String[] args) { Trial trial = new Trial(); trial.run(); } } ``` 在审讯类中,我们模拟了每两个囚犯之间的选择,根据选择计算并更新刑罚。最后,我们输出每个囚犯的刑罚。 以上是用Java实现百囚问题的简单示例,可以根据需要进行扩展和修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值