51Nod-1714-B君的游戏

235 篇文章 1 订阅
182 篇文章 3 订阅

ACM模版

描述

描述

题解

典型的Nim游戏,需要求SG函数,打表暴力即可。

代码

#include <cstdio>

typedef unsigned long long ull;

const int MAX_DIG = 64;

int sg[] = {0, 1, 2, 4, 8, 16, 32, 64, 128, 255, 256, 512,
    1024, 2048, 3855, 4096, 8192, 13107, 16384, 21845,
    27306, 32768, 38506, 65536, 71576, 92115, 101470,
    131072, 138406, 172589, 240014, 262144, 272069,
    380556, 524288, 536169, 679601, 847140, 1048576,
    1072054, 1258879, 1397519, 2005450, 2097152, 2121415,
    2496892, 2738813, 3993667, 4194304, 4241896, 4617503,
    5821704, 7559873, 8388608, 8439273, 8861366, 11119275,
    11973252, 13280789, 16777216, 16844349, 17102035,
    19984054, 21979742, 23734709};

int main()
{
    int n;

    while (scanf("%d", &n) == 1)
    {
        ull ans = 0, a;
        for (int i = 0; i < n; i++)
        {
            scanf("%llu\n", &a);
            int h = 0;
            ull d = 1;
            for (int i = 0; i < MAX_DIG; i++)
            {
                //  判断二进制位有几个1
                if ((d << i) & a)
                {
                    h++;
                }
            }
            ans ^= sg[h];
        }
        if (ans == 0)
        {
            puts("L");
        }
        else
        {
            puts("B");
        }
    }
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值