首页 > 其他 > 详细

巴仕博弈 + 威佐夫博弈

时间:2019-05-02 11:06:05      阅读:116      评论:0      收藏:0      [点我收藏+]

既然会了尼姆博弈和SG函数,那么巴仕博弈和威佐夫博奕照理说应该是不在话下了

巴什博奕:

两个顶尖聪明的人在玩游戏,有n个石子,每人可以随便拿1到m个石子,不能拿的人为败者,问谁会胜利

巴什博奕是博弈论问题中基础的问题

它是最简单的一种情形对应一种状态的博弈

博弈分析

如果有m+1个石子,那么先手必定无法取完全部,但后手可以取完剩下的部分,使得先手没有石子可以取,那么这个时候先手必败,

那么假设石子总数为(m+1)*r+n,r,n都为自然数,且n<m+1,那么如果我们先手,当r≠0时,我们只需要取走n个石子,那么剩下的是(m+1)*r个石子,那么无论对手如何取,我们只需取走和和他取走数和为m+1的石子数就可保证必胜,

若是n=0,那么我们相当于前面一种情况的后手,即为必败态

例题:http://acm.hdu.edu.cn/showproblem.php?pid=1846

题意:裸巴仕博弈

代码:

技术分享图片
 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 int main()
 4 {
 5     int t;
 6     cin>>t;
 7     while(t--)
 8     {
 9         int n,m;
10         cin>>n>>m;
11         if(n%(m+1))
12             cout<<"first"<<endl;
13         else 
14             cout<<"second"<<endl;
15     }
16     return 0;
17 }
View Code

威佐夫博奕:

有两堆各若干个物品,两个人轮流从任一堆取至少一个或同时从两堆中取同样多的物品,规定每次至少取一个,多者不限,最后取光者得胜。

我们可以用SG函数来判断胜负,但是让我们从正面出发去解解看

1,我们用(a[k],b[k])(a[k] ≤ b[k] ,k=0,1,2,...,n)表示两堆物品的数量并称其为局势。

2,如果甲面对(0,0),那么甲已经输了,这种局势我们称为奇异局势。

3,奇异局(举例)

首先列举人们已经发现的前几个奇异局势:(0,0)、(1,2)、(3,5)、(4,7)、(6,10)

(8,13)、(9,15)、(11,18)、(12,20)。

通过观察发现:a[0]=b[0]=0,a[k]是未在前面出现过的最小自然数,而 b[k]= a[k] + k。

4,奇异局势有如下三条性质:

1)任何自然数都包含且仅包含在一个奇异局势中。

2)任意操作都可以使奇异局势变为非奇异局势。

3)必有一种操作可以使非奇异局势变为奇异局势。

5,奇异局势公式:

a[k]=[k*(1+√5)/2],b[k]=a[k]+k。

(k=0,1,2......,[ ]表示取整)

有趣的是,式中的(1+√5)/2正是黄金分割比例。

HDU-1527(取石子游戏) http://acm.hdu.edu.cn/showproblem.php?pid=1527

题意:威佐夫博弈

技术分享图片
 1 //HDU-1527(威佐夫博弈取石子游戏)
 2 #include<bits/stdc++.h>
 3 using namespace std;
 4 typedef long long ll;
 5 int main()
 6 {
 7     ll n,m;
 8     while(cin>>n>>m)
 9     {
10         if(n>m)
11         swap(n,m);
12         double r=(sqrt(5.0)+1)/2;
13         if(n==(ll)((m-n)*r))
14         cout<<0<<endl;
15         else 
16         cout<<1<<endl;
17     }
18     return 0;
19  } 
View Code

 

巴仕博弈 + 威佐夫博弈

原文:https://www.cnblogs.com/graytido/p/10776628.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!