ECNU 1328 Stripes (sg函数)

看了张一飞大神的论文,开始找题做,上面提到的一个就是ecnu上的题

链接:http://www.acm.cs.ecnu.edu.cn/problem.php?problemid=1328

题目大意:给定red、green、blue三种长度分别为c、z、n的矩形条纹,要求用这三种矩形条纹来cover大小为p x 1的game
board,第一个不能再cover的选手为输。问先手是否能赢。

又有一种说法:

题意:其实就是给你L颗石子,你可以取连续的C颗石子,或者连续的Z颗石子,或者连续的N颗石子,谁不能取了,谁就输了,问甲乙两人谁有必胜策略。

都大同小异。

此题SG函数也要重新设计,因为每次操作后会变成两部分,需要将两部分异或才能算出结果

上个代码:

?





1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

#include <stdio.h>

#include <stdlib.h>

#include <string.h>

int sg[1005],hash[1005],f[1005];

void
GetSG(int
n)

{

    int
i,j;

    memset(sg,0,sizeof(sg));

    for(i=0;i<=n;i++)

    {

        memset(hash,0,sizeof(hash));

        for(j=1;j<=3;j++)

            for(int
k=f[j];k<=i;k++)

        {

            int
tmp=sg[k-f[j]]^sg[i-k];

            hash[tmp]=1;

        }

        for(j=0;j<=n;j++)

        {

            if(!hash[j])

            {

                 sg[i]=j;

                 break;

            }

        }

    }

}

int 
main()

{

    int
i,j,k,t;

    while(scanf("%d%d%d",&f[1],&f[2],&f[3])!=EOF)

    {

        scanf("%d",&k);

        GetSG(1000);

        for(i=0;i<k;i++)

        {

            scanf("%d",&t);

            if(sg[t])

                printf("1\n");

            else

                printf("2\n");

        }

    }

    return
0;

}

  

ECNU 1328 Stripes (sg函数),布布扣,bubuko.com

时间: 2024-04-18 17:20:48

ECNU 1328 Stripes (sg函数)的相关文章

zoj 2083 Win the Game(博弈SG函数)

题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=1083 题意差不多是这样,给你n条线的长度,让你染色,每次只能染2个长度单位,让你先染,问是否能赢的胜利 其实这题和取石子的那题(ECNU 1328 Stripes)差不多,都要考虑子情况,一条线染色后变成两段,要分别考虑 上个代码: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25

TYVJ 2049 魔法珠 sg函数

题意:链接 方法:sg函数 解析: tyvj的题大部分都没题解啊- - 不过这样貌似会更好?感觉做这的题都需要自己动脑啊- - 虽然嘴上说着好烦然而心里觉得好评? 回归正题 设sg[x]表示数x的sg值,这好像是废话 然后对于读入的a[i],将所有的a[i]的sg值异或起来如果不是零则先手赢反之后手 维护的时候有个坑. 每次求约数的时候,数组要在sg里开,因为如果递归下去的话,全局变量的话会被更改,会被坑死. 然后就是怎么维护了 对于x,先求约数 之后枚举哪个数不取,将其他的异或(或者先都异或起

hdu1848 Fibonacci again and again(SG函数博弈)

现在换是看不明白SG函数的求法什么的 暂时先当模板题吧 函数mex1就是求g(x) 然后异或 #include<cstdio> #include<iostream> #include<algorithm> #include<cstring> using namespace std; int k,fibo[100],f[10001]; int mex1(int p){ int i,t; bool g[101]={0}; for(i=0;i<k;i++){

HDU 2897-邂逅明下(sg函数)

邂逅明下 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit Status Practice HDU 2897 Appoint description:  System Crawler  (2015-03-13) Description 当日遇到月,于是有了明.当我遇到了你,便成了侣. 那天,日月相会,我见到了你.而且,大地失去了光辉,你我是否成侣?这注定是个凄美的故事.(以上是废

hdu 1536 S-Nim 博弈论,,求出SG&#39;函数就可以解决

S-Nim Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 4975    Accepted Submission(s): 2141 Problem Description Arthur and his sister Caroll have been playing a game called Nim for some time now

SG函数

转自:Angel_Kitty Sprague-Grundy定理(SG定理): 游戏和的SG函数等于各个游戏SG函数的Nim和.这样就可以将每一个子游戏分而治之,从而简化了问题.而Bouton定理就是Sprague-Grundy定理在Nim游戏中的直接应用,因为单堆的Nim游戏 SG函数满足 SG(x) = x.对博弈不是很清楚的请参照http://www.cnblogs.com/ECJTUACM-873284962/p/6398385.html进行进一步理解. SG函数: 首先定义mex(min

算法笔记--sg函数详解及其模板

sg函数大神详解:http://blog.csdn.net/luomingjun12315/article/details/45555495 模板: int f[N],SG[N]; bool S[M]; void getSG(int n) { memset(SG,0,sizeof(SG)); for(int i=1;i<=n;i++) { memset(S,false,sizeof(S)); for(int j=1;f[j]<=i&&j<M;j++) { S[SG[i-f

Nim 游戏、SG 函数、游戏的和

Nim游戏 Nim游戏定义 Nim游戏是组合游戏(Combinatorial Games)的一种,准确来说,属于"Impartial Combinatorial Games"(以下简称ICG).满足以下条件的游戏是ICG(可能不太严谨):1.有两名选手:2.两名选手交替对游戏进行移动(move),每次一步,选手可以在(一般而言)有限的合法移动集合中任选一种进行移动:3.对于游戏的任何一种可能的局面,合法的移动集合只取决于这个局面本身,不取决于轮到哪名选手操作.以前的任何操作.骰子的点数

hdu1847(sg函数&amp;yy)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1847 题意:中文题诶- 思路:直接sg函数打表即可,观察打表的结果发现是有规律的,sg函数的值只为0, 1, 2,所以我们只需n%3即可得出答案; 回过头来我们可以这样想,对于3的倍数的数,无论如何操作,最后必定会到达3这点,因为每次只能减2的幂,那么显然这种情况下先手会败; 代码: 1 #include <iostream> 2 #include <string.h> 3 #defi