预测玩家输赢,博弈论问题
Predict player win or lose, game theory question
我正在尝试解决这个问题。
问题描述:给定 n*m 网格,每个单元格要么为空(用 .( 表示,要么有一个石头(用 * 表示(。两名玩家轮流,每个回合可以
:1.将石头移到其相邻的右侧单元格(如果该单元格为空(
2.从网格中完全取出一块石头。
我们必须找到哪个玩家会赢。
基本上我的方法是,只要石头的数量和可能的向右移动是偶数/奇数,反之亦然,第一个玩家总是可以获胜,因为我们总是可以将其减少到偶数 - 根据我的说法,这是失败状态。
但我得到了错误的答案。 我找不到我出错的地方。
int main()
{
int i,j,n,m,cnt,pos;
char ch;
while(true)
{
cin>>n>>m;
if(n==0 && m==0)break;
cnt=pos=0; //cnt store count of stones
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
{
cin>>ch;
if(ch=='*')
{
cnt++;
pos+=(m-j-1); // this stone can be moved to m-j-1 places to right
}
}
}
if(cnt==1 || ((cnt&1)!=(pos&1)))cout<<"Player with first turn Wins"<<"n";
else cout<<"Player with second turn Wins"<<"n";
}
return 0;
}
你的算法有逻辑问题,根据你的逻辑,先动的人总是赢。假设你有一个 3x1 的网格,你有两块石头,让数组如下:{full,full,empty},现在在这种情况下,第一个移动的人总是会输,假设他向右移动它会变成 {full, empty, full} 然后第二个人将另一个石头移动到右侧, {空,满,满} 然后他别无选择,只能移除石头,第二个玩家将移除另一块石头,导致最终数组:{空,空,空} 因此第一个玩家输了,如果第一个玩家用他的第一个动作移除一块石头,第二个玩家将移除第二个: 再次导致 {空、空、空} 组合。所以你不能只是假设先走的玩家总是赢。
谢谢 陈云飞
相关文章:
- 警告处理为错误这里有什么问题
- 最小硬币更换问题(自上而下方法)
- 为"adjacent"变量赋值时出现问题
- 我的神经网络不起作用 [XOR 问题]
- 在Ubuntu 16.04上安装Cilk时出现问题
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 编译包含字符串的代码时遇到问题
- Project Euler问题4的错误解决方案
- 问题:什么是QAbstractItemView::NoEditTriggers的反面
- 在编译C++代码(具有dlib和opencv)到WASM时面临问题
- 在进程中对同一管道进行读取和写入时C++管道出现问题
- 静态数据成员的问题-修复链接错误会导致编译器错误
- C++ 雷神库 - 使用资源加载器类时出现问题(不命名类型)
- 一个关于在C++中重载布尔运算符的问题
- 首要问题的答案让值班员搞错了
- setlocale的C++土耳其字符串问题
- 如何重构类层次结构以避免菱形问题
- 基于boost的程序的静态链接——zlib问题
- C++格式化输出问题
- 预测玩家输赢,博弈论问题