模拟百囚徒问题

一道非常著名的“反直觉”智力题_哔哩哔哩_bilibili一道非常著名的“反直觉”智力题:——有100名编号分别为1,2,3......100的囚犯。——每个囚犯的编号都写在一张纸条上。这100张纸条,被随机放入一个房间里的100个外观相同的盒子里。每个盒子里放一张纸条。——每个囚犯可以单独进入房间一次,任意查看50个盒子,看完后要将盒子盖上,不留下任何痕迹。如果他能恰好看到“自己的编号”,视为完成任务,需要立刻离开房间。——囚犯们可以在开始之前讨论策略, 视频播放量 608827、弹幕量 964、点赞数 18316、投硬币枚数 1722、收藏人数 12315、转发人数 5070, 视频作者 lovelyff998, 作者简介 ,相关视频:数学有一个致命的缺陷,你应该站在哪个位置,才能活到最后?,无限巧克力悖论,美国竞赛题,老外半天没算对,中国学生一招搞定,万字解析:今天的游戏技术究竟发展到了什么程度?,怎样解释祖父悖论?,人 类 低 质 量 翻 译 鉴 赏(14),为什么成功人士从来不写待办清单(To-Do List) ?► 她提到的这个方法更有效 - 百万人气网红企业家 Rachel Hollis 瑞秋‧霍利(中英字幕),能够感受“炁”的身心小游戏,这个世界最大的幻觉https://www.bilibili.com/video/BV1kt4y1t75F?p=1&share_medium=android&share_plat=android&share_session_id=55f1ff0e-fda4-43be-8c5a-112768033498&share_source=QQ&share_tag=s_i×tamp=1656936860&unique_k=Ru3JMdE&vd_source=78c5a56b2b804449168dbad7346576d9

#include <iostream>
#include <time.h>
using namespace std;
const int N = 100;
int dfs(int a[], int x, int vis[]) {
    if (vis[a[x]]) {
        return 0;
    }
    vis[a[x]] = 1;
    return dfs(a, a[a[x]], vis) + 1;
}
int main() {
    srand(time(0));
    int cnt = 0, T = 100000;
    for (int round = 0; round < T; round++) {
        int a[128] = {0};
        for (int i = 1; i <= N; i++) {
            a[i] = i;
        }
        for (int i = N; i > 1; i--) {
            int r = 1 + rand() % i;
            int t = a[i];
            a[i] = a[r];
            a[r] = t;
        }
        int vis[128] = {0};
        for (int i = 1; i <= N; i++) {
            if (dfs(a, i, vis) > (N >> 1)) {
                cnt++;
                break;
            }
        }
    }
    cout << 1.0 * cnt / T;
    return 0;
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
问题是一个经典的合作与背叛问题,也被称为囚徒困境。在问题中,有一个罪犯在独立审讯的情况下,他们被指控犯有某项罪行,并面临着不同的刑罚。每个囚犯可以选择合作或背叛其他囚犯。 如果一个囚犯选择合作,而其他囚犯也选择合作,那么每个人都将得到一个较轻的刑罚。如果一个囚犯选择背叛,而其他囚犯选择合作,那么背叛者会获得较轻的刑罚,而其他合作者会受到更严重的刑罚。如果所有囚犯都选择背叛,那么每个人都将获得较严重的刑罚。 要用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、付费专栏及课程。

余额充值