博客
关于我
博弈论讲解(二)
阅读量:164 次
发布时间:2019-02-27

本文共 657 字,大约阅读时间需要 2 分钟。

斐波那契博弈

游戏规则

有一堆数量为n的石子,游戏双方轮流取石子,满足以下条件:

  • 先手不能在第一次将所有石子取完;
  • 之后每次可以取的石子数介于1到对手刚取的石子数的2倍之间(包含1和对手刚取的石子数的2倍)。
  • 约定取走最后一个石子的人为赢家。

    必败态

    当n为斐波那契数时,先手必败。

    证明

    齐肯多夫(zeckendorf)定理:任何正整数都可以表示成若干个不连续的斐波那契数(不包括第一个斐波那契数)之和。

    例如,n=54可以写成:n=2+5+13+34。

    • 先手A取2个,后手B在1~4范围内取石子。由于B必须至少取1个,最多取4个,但5已经被A取走了,因此B只能取5的最后一个。
    • 接下来,A可以拿走13的最后一个,接着拿走34的最后一个,这样A就赢了。

    反之,如果n是斐波那契数,A无法阻止B按照斐波那契数规则取走最后一个石子,从而让B获胜。

    尼姆博弈

    游戏规则

    有三堆石子,数量分别为(a, b, c)。两个人轮流从某一堆中取任意多的石子,规定每次至少取一个,多者不限。最后取光者得胜。

    必败态

    如果三堆石子数量的异或(a ^ b ^ c)为0,则先手必败;否则先手必胜。

    证明

    略述。

    代码

    for(int i = 1; i <= n; i++) {    sum ^= ans;}if(sum == 0) {    cout << "后手必胜";}

    公平组合博弈

    公平组合博弈属于Impartial Combinatorial Games,属于Nim游戏的一种变种。其核心是通过数学模型确定必败态和必胜态。

    转载地址:http://ymwb.baihongyu.com/

    你可能感兴趣的文章
    Objective-C实现EM算法(附完整源码)
    查看>>
    Objective-C实现entropy熵算法(附完整源码)
    查看>>
    Objective-C实现euclidean distance欧式距离算法(附完整源码)
    查看>>
    Objective-C实现Euclidean GCD欧几里得最大公约数算法(附完整源码)
    查看>>
    Objective-C实现euclideanDistance欧氏距离算法(附完整源码)
    查看>>
    Objective-C实现euler method欧拉法算法(附完整源码)
    查看>>
    Objective-C实现euler modified变形欧拉法算法(附完整源码)
    查看>>
    Objective-C实现eulerianPath欧拉路径算法(附完整源码)
    查看>>
    Objective-C实现Eulers TotientFunction欧拉函数算法(附完整源码)
    查看>>
    Objective-C实现eulers totient欧拉方程算法(附完整源码)
    查看>>
    Objective-C实现EulersTotient欧拉方程算法(附完整源码)
    查看>>
    Objective-C实现eval函数功能(附完整源码)
    查看>>
    Objective-C实现even_tree偶数树算法(附完整源码)
    查看>>
    Objective-C实现Exceeding words超词(差距是ascii码的距离) 算法(附完整源码)
    查看>>
    Objective-C实现exchange sort交换排序算法(附完整源码)
    查看>>
    Objective-C实现ExponentialSearch指数搜索算法(附完整源码)
    查看>>
    Objective-C实现extended euclidean algorithm扩展欧几里得算法(附完整源码)
    查看>>
    Objective-C实现ExtendedEuclidean扩展欧几里德GCD算法(附完整源码)
    查看>>
    Objective-C实现external sort外排序算法(附完整源码)
    查看>>
    Objective-C实现Factorial digit sum阶乘数字和算法(附完整源码)
    查看>>