有趣的博弈(先手后手问题)

2023-12-14 23:10

本文主要是介绍有趣的博弈(先手后手问题),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

巴什博弈

两个聪明的人在玩一个游戏,当前有一堆n个石头,两个人每次可以从这堆石头当中取出[1,m]个石头,拿完石头的人赢得比赛。两个人每次得决策总是最利于自己的。 请问是先手赢还是后手赢。

再遇到此类问题时 需要将石头分为m+1堆,这时可以分为三种情况:

1.石头总数n小于等于m,那么先手一次就能拿完所有的石头,所以先手赢

2.石头总数n可以用k*(m+1)表示时,当先手拿走a个石头后手可以拿出m+1-a个石头此时石头堆的总数可以用(k-1)*(m+1)表示,先手拿走石头时后手总是可以维护(k-b)(m+1)个石头,直到最后一定是后手拿完石头,所以后手赢

3.石头总数n可以用k*(m+1)+x表示,此时先手拿走x个石头那么此时秩序又回到了第二种情况,所以先手一定赢

综上,当石头总数n能够整除m+1时后手赢,此外先手赢。

尼姆博弈

两个聪明的人在玩一个游戏,当前有n堆不同的石头,两个人在轮流拿取时可以将某一堆的石头拿走至少一个至多全部,不能不拿去且一轮只能在一堆石头里拿,最后一个将石头拿完的人获胜。请问是先手赢还是后手赢。

我们先考虑简单的情况

当n为1时,先手一定赢。当n为2时,用a,b表示两堆石头的数量,若a=b时先手拿去一定石头后导致a!=b但后手可以通过拿走另一堆相同的石头维持a=b的状态且两堆的石头总是在逐渐减少的直到a=b=0,所以此时后手总是赢,若a!=b时先手拿走某一堆的石头可以造成a=b的情况那么又回到了上一种情况但此时的先手是上一种情况的后手,所以a!=b的情况先手总是赢。那么我们现在可以将情况推广到n堆石头

我们引入尼姆和这一概念:将所有堆中的石头数量转化为二进制进行异或运算的结果则为尼姆和,当尼姆和为零时后手一定赢否则先手一定赢。这时我们发现此结论也是适用于以上n为1和2的情况的。

证明如下: 异或^:当两个数相等时为0不同时为1 (1^1=0,1^0=1,0^0=0,0^1=1)。同时我们给出两个定理:

 

1.当尼姆和为零时无论怎么拿去,拿去后的物品尼姆和一定不为零

2.当尼姆和不为零时,总是存在一种拿去的方法使得拿去后的物品尼姆和为零

思路:当尼姆和为零时先手方无论如何拿取,拿取后的尼姆和总是不为零,而后手方总是可以选择拿取的方式使得尼姆和再次为零同时石头的数量也在严格的减少当所以石头都拿完的情况也是尼姆和为零的情况所以后手一定赢。当尼姆和不为零时先手可以通过拿去使得尼姆和为零,那么此时先手一定赢。

那么现在只需要证明两个定理存在即可。

我们假设一堆石头由a1,a2,a3,a4,,,,an组成。假设当前密姆和为零也就是a1^a2^a3^a4^......^an=0 此时先手拿走一堆石头中的若干个石头后造成a1^a2^a3^a4^....^an=k 此时可以视为a1^a2^a3^a4^....^an^k=0

我们假设k转化为二进制后最高位1位于x位置那么在a1至an当中至少存在一个数ai使得ai的二进制第x位同样也为1(因为k的二进制第x位是由a1至an二进制第x位异或得来的,若该位置全为0则k的第x位也同样为0)我们可以拿去ai位置的石头使得ai位置的石头变为ai^k(这里ai^k一定是小于ai的,因为二进制第x位都为1那么异或后第x位为0,ai高于x的位 异或后不变,低于x的位因为x位异或后为0所以整个数一定减小)所以只需在ai位拿走ai-ai^k就可以使得尼姆和不为零的组合变为零。到这里我们已经证得第二个定理成立接下来只需要证明第一个定理

假设(a1,a2,a3,a4,,,an)尼姆和为a 拿取后(b1,b2,b3,b4,,,bn)尼姆和为b

b=0^b

 =(a^a)^b

 =a^(a^b)

 =a^(a1^a2^a3^a4,,,^an)^(b1^b2^b3^b4,,,^bn)

 =a^(ai)^(bi)

也就是拿走第i堆石头使得ai变为bi。若a为零因为ai!=bi所以b!=0。也就是当尼姆和为零时无论怎么拿去,拿去后的物品尼姆和一定不为零 那么第一个定理也就证明了

阶梯博弈(尼姆博弈进阶)

两个聪明的人在玩一个游戏,在n级阶梯的每一级上有不同的小石子,两个人可以依次进行一个操作:讲某一级阶梯阶梯上的石子至少一个至多全部放在低一级的阶梯上当某一人将阶梯上的石头全部拿走以至于下一人没有石头拿取时为获胜。

35eb06d72f504d289113bc7a87920bd2.png

 如图所示为5级阶梯的例子 当所有石子被拿到地面上(0级阶梯)时游戏结束。

我们先只讨论奇数级阶梯的尼姆和,当尼姆和不为0时先手必胜否则后手必胜。证明如下:

 

先手进行一次拿取石头的操作将尼姆和改变为0,此时后手有两种操作方法 第一种是将奇数位的石子拿到偶数位试图通过减少某一奇数级的石子数量打破尼姆和为0的状态,但是之后先手仍可以通过移动某一奇数位的的石子到偶数位的操作维持尼姆和为0,第二种是将偶数位的石子拿到奇数位试图通过增加某一奇数级的石子数量打破尼姆和为零,但是之后先手仍可以把后手拿到该奇数级的石子相同数量的拿到更低一级的偶数位。我们可以发现这几种操作都是使阶梯石子一步一步往0阶梯移动的过程直到最后阶梯上没有石子也就是最终尼姆和为0的情况。但是尼姆和为0的情况总是在先手手上所已先手必胜

 

这篇关于有趣的博弈(先手后手问题)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/494240

相关文章

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

poj2505(典型博弈)

题意:n = 1,输入一个k,每一次n可以乘以[2,9]中的任何一个数字,两个玩家轮流操作,谁先使得n >= k就胜出 这道题目感觉还不错,自己做了好久都没做出来,然后看了解题才理解的。 解题思路:能进入必败态的状态时必胜态,只能到达胜态的状态为必败态,当n >= K是必败态,[ceil(k/9.0),k-1]是必胜态, [ceil(ceil(k/9.0)/2.0),ceil(k/9.

hdu3389(阶梯博弈变形)

题意:有n个盒子,编号1----n,每个盒子内有一些小球(可以为空),选择一个盒子A,将A中的若干个球移到B中,满足条件B  < A;(A+B)%2=1;(A+B)%3=0 这是阶梯博弈的变形。 先介绍下阶梯博弈: 在一个阶梯有若干层,每层上放着一些小球,两名选手轮流选择一层上的若干(不能为0)小球从上往下移动,最后一次移动的胜出(最终状态小球都在地面上) 如上图所示,小球数目依次为

购买磨轮平衡机时应该注意什么问题和技巧

在购买磨轮平衡机时,您应该注意以下几个关键点: 平衡精度 平衡精度是衡量平衡机性能的核心指标,直接影响到不平衡量的检测与校准的准确性,从而决定磨轮的振动和噪声水平。高精度的平衡机能显著减少振动和噪声,提高磨削加工的精度。 转速范围 宽广的转速范围意味着平衡机能够处理更多种类的磨轮,适应不同的工作条件和规格要求。 振动监测能力 振动监测能力是评估平衡机性能的重要因素。通过传感器实时监

缓存雪崩问题

缓存雪崩是缓存中大量key失效后当高并发到来时导致大量请求到数据库,瞬间耗尽数据库资源,导致数据库无法使用。 解决方案: 1、使用锁进行控制 2、对同一类型信息的key设置不同的过期时间 3、缓存预热 1. 什么是缓存雪崩 缓存雪崩是指在短时间内,大量缓存数据同时失效,导致所有请求直接涌向数据库,瞬间增加数据库的负载压力,可能导致数据库性能下降甚至崩溃。这种情况往往发生在缓存中大量 k

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

nudepy,一个有趣的 Python 库!

更多资料获取 📚 个人网站:ipengtao.com 大家好,今天为大家分享一个有趣的 Python 库 - nudepy。 Github地址:https://github.com/hhatto/nude.py 在图像处理和计算机视觉应用中,检测图像中的不适当内容(例如裸露图像)是一个重要的任务。nudepy 是一个基于 Python 的库,专门用于检测图像中的不适当内容。该

【VUE】跨域问题的概念,以及解决方法。

目录 1.跨域概念 2.解决方法 2.1 配置网络请求代理 2.2 使用@CrossOrigin 注解 2.3 通过配置文件实现跨域 2.4 添加 CorsWebFilter 来解决跨域问题 1.跨域概念 跨域问题是由于浏览器实施了同源策略,该策略要求请求的域名、协议和端口必须与提供资源的服务相同。如果不相同,则需要服务器显式地允许这种跨域请求。一般在springbo

题目1254:N皇后问题

题目1254:N皇后问题 时间限制:1 秒 内存限制:128 兆 特殊判题:否 题目描述: N皇后问题,即在N*N的方格棋盘内放置了N个皇后,使得它们不相互攻击(即任意2个皇后不允许处在同一排,同一列,也不允许处在同一斜线上。因为皇后可以直走,横走和斜走如下图)。 你的任务是,对于给定的N,求出有多少种合法的放置方法。输出N皇后问题所有不同的摆放情况个数。 输入