SG函数

本文介绍了一种适用于甲乙两人取石子游戏及其类似游戏的通用解法。该方法通过定义局面的数学表示及操作,利用二进制数运算判断胜负策略。适用于每一步仅能对一堆石子进行操作且操作受限于石子数量或常数的游戏。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

适用范围和限制条件:

1.甲乙两人取石子游戏及其类似的游戏;

2.每一步只能对某一堆石子进行操作;

3.每一步操作的限制,只与这堆石子的数目或一些常数有关;

4.操作在有限步内终止,并不会出现循环;

5.谁无法继续操作,谁就是输家。

 

此类搏弈游戏的一般性解法:

用一个n元组(a1, a2, …, an),来描述游戏过程中的一个局面。

用符号#S,表示局面S所对应的二进制数。

用符号$(x),表示局面(x)的下一步所有可能出现的局面的集合。

定义集合g(x):设$(x)={S1, S2, …, Sk},则g(x)={#S1, #S2, …, #Sk}。

令非负整数集为全集,集合G(x)表示集合g(x)的补集。

定义函数f(n):f(n)=min{G(n)},即f(n)等于集合G(n)中的最小数。

设局面S=(a1, a2, …, an),#S=f(a1)+f(a2)+…+f(an),采用二进制数的加法。

#S0,则先行者有必胜策略;若#S=0,则后行者有必胜策略。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值