博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ 2484 A Funny Game【博弈】
阅读量:5072 次
发布时间:2019-06-12

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

相比数据结构的题。。感觉这种想啊想的题可爱多了~~~代码量还少。。。。


题目链接:

题意:

一圈n个硬币,两人轮流从中取一或两个硬币,(只能取相邻的两枚硬币),取完的获胜,问谁赢?

分析:

这里注意,连续的硬币中取出若干个后,被分割开的就不算连续的硬币了。

首先还是找是否存在对称状态,只要是存在对称状态,后手模仿先手,最后后手必赢。
假设先手第一次拿走了1或者2个硬币,圈被分裂成一条链,后手在链的中间部位拿走1或者2个硬币,将链分为两条对称的子链,这样便出现对称状态了。后手必赢!
但是注意一次是最多可以取2个硬币的,所以在硬币数小于等于2时,先手赢。

代码:

#include
using namespace std;int main (void){ int n; while(cin>>n && n){ if(n <= 2) cout<<"Alice"<

这类游戏就是要找对称状态,然后完全模仿对手,最终必赢!

转载于:https://www.cnblogs.com/Tuesdayzz/p/5758688.html

你可能感兴趣的文章
关于TFS2010使用常见问题
查看>>
软件工程团队作业3
查看>>
python标准库——queue模块 的queue类(单向队列)
查看>>
火狐、谷歌、IE关于document.body.scrollTop和document.documentElement.scrollTop 以及值为0的问题...
查看>>
深入理解JVM读书笔记--字节码执行引擎
查看>>
vue-搜索功能-实时监听搜索框的输入,N毫秒请求一次数据
查看>>
批处理 windows 服务的安装与卸载
查看>>
React文档翻译 (快速入门)
查看>>
nodejs fs路径
查看>>
动态规划算法之最大子段和
查看>>
linux c:关联变量的双for循环
查看>>
深入浅出理解zend framework(三)
查看>>
python语句----->if语句,while语句,for循环
查看>>
javascript之数组操作
查看>>
LinkedList源码分析
查看>>
TF-IDF原理
查看>>
用JS制作博客页面背景随滚动渐变的效果
查看>>
JavaScript的迭代函数与迭代函数的实现
查看>>
一步步教你学会browserify
查看>>
Jmeter入门实例
查看>>