閱讀316 返回首頁    go 阿裏雲 go 技術社區[雲棲]


POJ1740

這題想了好久都沒想出來 然後在網上搜的題解 終於明白了。。。 

當為1堆的時候 先手為必勝態 

當為2堆並且兩堆都相同時 先手怎麼走後手怎麼走就行了

當為3堆 先手隻要一次拿成兩堆且相同 的情況就是必勝態

4堆的時候隻要看排序後 兩堆 兩堆是否相同就行了 

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
using namespace std;

bool f[1005];

int main()
{
    int n;
    while (scanf("%d", &n)&& n)
    {
        memset(f, 0, sizeof(f));
        int ans = 0;
        for (int i = 0; i < n; i++)
        {
            int a;
            scanf("%d", &a);
            if (f[a])
                ans--;
            else
                ans++;
            f[a] = !f[a];
        }
        if (ans)
            printf("1\n");
        else
            printf("0\n");
    }
    return 0;
}


最後更新:2017-04-04 07:03:34

  上一篇:go HDU1573 一元線性同餘方程組
  下一篇:go 查詢選修了全部課程的學生姓名