C++ 看不懂问题 提供一下思路呗

 我来答
蓝梓楠函树
2019-02-27 · TA获得超过3万个赞
知道小有建树答主
回答量:1.1万
采纳率:31%
帮助的人:689万
展开全部
博弈论问题,可以用
反推法
取胜者最后一次戳爆的气球数x一定满足1≤x≤3或1≤x≤5(取决于采取方案①还是②)
即落败者最后一次戳气球时剩余气球数一定为4(这里假设采用方案①,下同),为3或为5都会导致失败。由于双方都采取最优策略,可推得落败者倒数第二次戳气球时剩余气球数一定为8。所以你会发现这个问题实际上是一个
同余
问题。只要轮到你戳气球时,保证戳完后剩余气球数x满足x≡0(mod
4)即可取胜。为了满足这一条件,你需要:①在对方每次戳完气球后,自己下次戳爆的气球数和对方本轮戳爆气球数之和为4;②保证对方第一次戳球后剩下球数x不满足x≡0(mod
4)
若能满足条件①和②,则此游戏一定取胜。否则,必须采取方案二,尝试使对方每次戳球前总球数满足x≡0(mod
6)。若方案二也不能满足,则此游戏必败。
而你会发现,条件②实际上就相当于总球数n≡0(mod
4)。因此,当总球数n能被4
整除
时,应该采用方案①;同理,当总球数n能被6整除时,应该采用方案②。得到结论:当总球数n为4或6的倍数时,这个游戏可以取胜;否则,必定失败。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式