TYOI 1015 Game:博弈 结论【步数之和的奇偶性】

题意:

  明明和亮亮在玩一个游戏。

  桌面上一行有n个格子,一些格子中放着棋子。

  明明和亮亮轮流选择如下方式中的一种移动棋子(图示中o表示棋子,*表示空着的格子):

  (1)当一枚棋子的右边是空格子的话,可以将这枚棋子像右移动一格。

    **o***         ->           ***o**

  (2)当一枚棋子的右边连续两个都有棋子,并且这个棋子往右边数第3格没有棋子,那么可以将这个棋子可以跳过去那两个棋子

    **ooo*        ->           ***oo*

  当任何一枚棋子到达最右边的格子时,这枚棋子自动消失。

  当一方不能移动时,这方输。

  假设明明和亮亮都采取最优策略,明明先走,谁将取胜?

 

题解:

  走一步和走三步都是走奇数步。

  所以统计一下每个棋子到终点的步数之和tot。如果tot为奇数,则先手胜,否则后手胜。

 

AC Code:

 1 #include <iostream>
 2 #include <stdio.h>
 3 #include <string.h>
 4 
 5 using namespace std;
 6 
 7 int n,t;
 8 int tot;
 9 
10 int main()
11 {
12     cin>>t;
13     while(t--)
14     {
15         cin>>n;
16         tot=0;
17         char c;
18         for(int i=n-1;i>=0;i--)
19         {
20             cin>>c;
21             if(c=='o') tot+=i;
22         }
23         if(tot&1) cout<<"M"<<endl;
24         else cout<<"L"<<endl;
25     }
26 }

 

Game

【题目描述】

明明和亮亮在玩一个游戏。桌面上一行有n个格子,一些格子中放着棋子。明明和亮亮轮流选择如下方式中的一种移动棋子(图示中o表示棋子,*表示空着的格子):

1)当一枚棋子的右边是空格子的话,可以将这枚棋子像右移动一格。

**o***         ->           ***o**

2)当一枚棋子的右边连续两个都有棋子,并且这个棋子往右边数第3格没有棋子,那么可以将这个棋子可以跳过去那两个棋子

**ooo*        ->           ***oo*

当任何一枚棋子到达最右边的格子时,这枚棋子自动消失。当一方不能移动时,这方输。假设明明和亮亮都采取最优策略,明明先走,谁将取胜?

转载于:https://www.cnblogs.com/Leohh/p/7674066.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值