题目链接

先打一个sg函数的表,找找规律,发现sg函数可以递归求解

打表代码如下

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

;

bool vis[N];
int sg[N];
int k;

void init()
{
    memset(sg,,sizeof(sg));
    memset(vis,false,sizeof(vis));
    sg[]=,sg[]=;
    ;i<=;i++)
    {
        memset(vis,,sizeof(vis));
        )/k;j<i;j++)
            vis[sg[j]]=true;
        ;j<=;j++)
            if(vis[j]==false)
            {
                sg[i]=j;
                break;
            }
    }
}

int main()
{
    ios::sync_with_stdio(false);
    while(cin>>k)
    {
        init();
        ;i<=;i++)
        {
            printf(? '\n':' ');
        }
        puts("");
        puts("");
    }
}

得到的一个结果

k=
sg[  ]=   sg[  ]=   sg[  ]=   sg[  ]=
sg[  ]=   sg[  ]=   sg[  ]=   sg[  ]=
sg[  ]=   sg[ ]=   sg[ ]=   sg[ ]=
sg[ ]=   sg[ ]=  sg[ ]=  sg[ ]=
sg[ ]=   sg[ ]=  sg[ ]=  sg[ ]=
sg[ ]=   sg[ ]=  sg[ ]=  sg[ ]=
sg[ ]=   sg[ ]=  sg[ ]=  sg[ ]=
sg[ ]=   sg[ ]=  sg[ ]=  sg[ ]=
sg[ ]=   sg[ ]=  sg[ ]=  sg[ ]=
sg[ ]=   sg[ ]=  sg[ ]=  sg[ ]=
sg[ ]=   sg[ ]=  sg[ ]=  sg[ ]=
sg[ ]=   sg[ ]=  sg[ ]=  sg[ ]=
sg[ ]=   sg[ ]=  sg[ ]=  sg[ ]=
sg[ ]=   sg[ ]=  sg[ ]=  sg[ ]=
sg[ ]=  sg[ ]=  sg[ ]=  sg[ ]=
sg[ ]=  sg[ ]=  sg[ ]=  sg[ ]=
sg[ ]=  sg[ ]=  sg[ ]=  sg[ ]=
sg[ ]=   sg[ ]=  sg[ ]=  sg[ ]=
sg[ ]=  sg[ ]=  sg[ ]=  sg[ ]=
sg[ ]=  sg[ ]=  sg[ ]=  sg[ ]= 

当然k可以改来改去地试

再之后,如果异或和不为0,要特殊处理下,也是根据打表的规律,具体方法见代码

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;

;
LL k;
int n;
LL a[N];

LL sg(LL x)
{
    ||x==) ;
    )
        )/k;
    return sg(x/k);
}

int main()
{
    while(~scanf("%d%lld",&n,&k))
    {
        LL ans=;
        ;i<=n;i++)
        {
            scanf("%lld",&a[i]);
            ans^=sg(a[i]);
        }
//        cout<<ans<<endl;
        if(ans)
        {
            int pos;
            LL y;
            ;i<=n;i++)
            {
                LL sgx=sg(a[i]),t=sgx^ans;
                pos=i;
                y=t+(t+k-)/(k-);
//                cout<<y<<' '<<(a[i]+k-1)/k<<endl;
                )
                {
                    if(y>=a[i]) break;
                    )/k)
                    {
                        printf("Alice %d %lld\n",pos,y);
                        ;
                    }
                    y=y*k+;
                }
            }
            printf("Alice %d %lld\n",pos,y);
        }
        else
            puts("Bob");
    }
}

51nod 1661: 黑板上的游戏(sg函数 找规律)的更多相关文章

  1. 51nod-1661 1661 黑板上的游戏(组合游戏)

    题目链接: 1661 黑板上的游戏 Alice和Bob在黑板上玩一个游戏,黑板上写了n个正整数a1, a2, ..., an,游戏的规则是这样的:1. Alice占有先手主动权.2. 每个人可以选取一 ...

  2. BZOJ 1228 E&G(sg函数+找规律)

    把一对石子堆看出一个子游戏.打出子游戏的sg表找规律.. 这个规律我是一定找不出来的... 对于i,j,如果 (i-1)%pow(2,k+1) < pow(2,k) (j-1)%pow(2,k+ ...

  3. 51nod_1661: 黑板上的游戏(sg函数 找规律)

    题目链接 先打一个sg函数的表,找找规律,发现sg函数可以递归求解 打表代码如下 #include<bits/stdc++.h> using namespace std; typedef ...

  4. HDU-4664 Triangulation 博弈,SG函数找规律

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4664 题意:一个平面上有n个点(一个凸多边形的顶点),每次可以连接一个平面上的两个点(不能和已经连接的 ...

  5. HDU 1517 A Multiplication Game (SG函数找规律)

    题意:两个玩家玩一个游戏,从 p = 1,开始,然后依次轮流选择一个2 - 9的数乘以 p,问你谁先凑够 p >= n. 析:找规律,我先打了一下SG函数的表,然后就找到规律了 我找到的是: 1 ...

  6. 组合游戏 - SG函数和SG定理

    在介绍SG函数和SG定理之前我们先介绍介绍必胜点与必败点吧. 必胜点和必败点的概念:        P点:必败点,换而言之,就是谁处于此位置,则在双方操作正确的情况下必败.        N点:必胜点 ...

  7. 【poj 3090】Visible Lattice Points(数论--欧拉函数 找规律求前缀和)

    题意:问从(0,0)到(x,y)(0≤x, y≤N)的线段没有与其他整数点相交的点数. 解法:只有 gcd(x,y)=1 时才满足条件,问 N 以前所有的合法点的和,就发现和上一题-- [poj 24 ...

  8. HDU 1536 S-Nim (组合游戏+SG函数)

    题意:针对Nim博弈,给定上一个集合,然后下面有 m 个询问,每个询问有 x 堆石子 ,问你每次只能从某一个堆中取出 y 个石子,并且这个 y 必须属于给定的集合,问你先手胜还是负. 析:一个很简单的 ...

  9. BZOJ1188 [HNOI2007]分裂游戏(SG函数)

    传送门 拿到这道题就知道是典型的博弈论,但是却不知道怎么设计它的SG函数.看了解析一类组合游戏这篇论文之后才知道这道题应该怎么做. 这道题需要奇特的模型转换.即把每一个石子当做一堆石子,且原来在第i堆 ...

随机推荐

  1. STL容器内数据删除

    STL中的容器按存储方式分为两类,一类是按以数组形式存储的容器(如:vector .deque):另一类是以不连续的节点形式存储的容器(如:list.set.map).在使用erase方法来删除元素时 ...

  2. 牛客提高D6t1 积木大赛

    分析 每次修改用二位差分记录一下 之后对于三维分别统计即可 代码 #include<iostream> #include<cstdio> #include<cstring ...

  3. 将原生JS和jquery里面的DOM操作进行了一下整理

    创建元素节点 1.原生: document.createElement("div") 2.jquery: $("<div></div>" ...

  4. windows10上使用一个tomcat部署2个项目

    前言:目前想在本机部署2个项目,网上查了之后,写下本篇随笔 1.准备工作 2.操作方法 3.运行2个项目 1.准备工作 2个war包(一个jprss.war和一个jenkins.war) 1个tomc ...

  5. Java 语言的类、属性、方法各有哪些修饰符?简述各修饰符的区别

    1. 类的修饰符分为:可访问控制符和非访问控制符两种. 可访问控制符是:公共类修饰符 public 非访问控制符有:抽象类修饰符 abstract :最终类修饰符 final 1.公共类修饰符 pub ...

  6. Oracle基本操作练习(一)

    --创建表空间 create tablespace test datafile 'c:\test.dbf' size 100m autoextend on next 10m; --删除表空间 drop ...

  7. 异步请求jquery action

    package com.tarena.action; import java.util.HashMap;import java.util.Map; import javax.annotation.Re ...

  8. 【Python—参数】*arg与**kwargs参数的用法

    在python中,这两个是python中的可变参数,*arg表示任意多个无名参数,类型为tuple;**kwargs表示关键字参数,为dict. # *允许你传入0个或任意个参数,这些可变参数在函数调 ...

  9. CVE-2013-2094 porting to x86-32 分析

    /* * linux 2.6.37-3.8.8 - x86 * @rikiji * * requires System.map and /dev/ptmx * this: http://zmbs.ne ...

  10. python学习第十九天三元运算符与php语言区别

    三元运算符是条件语句的简写,常见的条件语句写三行,三元运算符只需要写一行,python三元运算符是怎么写的呢 1,常见条件判断 if a<b: print(a) else: print(b) 2 ...