zoukankan      html  css  js  c++  java
  • An Ordinary Game(简单推导)

    An Ordinary Game


    Time limit : 2sec / Memory limit : 256MB

    Score : 500 points

    Problem Statement

    There is a string s of length 3 or greater. No two neighboring characters in s are equal.

    Takahashi and Aoki will play a game against each other. The two players alternately performs the following operation, Takahashi going first:

    • Remove one of the characters in s, excluding both ends. However, a character cannot be removed if removal of the character would result in two neighboring equal characters in s.

    The player who becomes unable to perform the operation, loses the game. Determine which player will win when the two play optimally.

    Constraints

    • 3≤|s|≤105
    • s consists of lowercase English letters.
    • No two neighboring characters in s are equal.

    Input

    The input is given from Standard Input in the following format:

    s
    

    Output

    If Takahashi will win, print First. If Aoki will win, print Second.


    Sample Input 1

    Copy
    aba
    

    Sample Output 1

    Copy
    Second
    

    Takahashi, who goes first, cannot perform the operation, since removal of the b, which is the only character not at either ends of s, would result in s becoming aa, with two as neighboring.


    Sample Input 2

    Copy
    abc
    

    Sample Output 2

    Copy
    First
    

    When Takahashi removes b from s, it becomes ac. Then, Aoki cannot perform the operation, since there is no character in s, excluding both ends.


    Sample Input 3

    Copy
    abcab
    

    Sample Output 3

    Copy
    First


    //有一个字符串,相邻的不能相同,两个人玩,一人每次可以删除除了首尾的任意一个,但是要保证删完不能相邻的相同,谁删到不能删就谁输,
    给一个字符串,问谁赢
     1 #include <stdio.h>
     2 #include <string.h>
     3  
     4 char str[100005];
     5 int main()
     6 {
     7     while (scanf("%s",str)!=EOF)
     8     {
     9         int len=strlen(str);
    10         int res;
    11         if (str[0]==str[len-1])
    12             res=len-3;
    13         else
    14             res=len-2;
    15         if (res%2==1)
    16             printf("First
    ");
    17         else printf("Second
    ");
    18     }
    19     return 0;
    20 }
    View Code





  • 相关阅读:
    闭包 (Closure)
    RSA算法
    HTTPS
    SSH
    HDU1754 I hate it_线段树(入门级别)
    HDU1166 敌兵布阵_线段树
    c++运算符优先级表
    归并排序练习.
    HDU 1969 精度二分
    uva10944 状态压缩bfs or DP
  • 原文地址:https://www.cnblogs.com/haoabcd2010/p/6187608.html
Copyright © 2011-2022 走看看