hdu 3980 Paint Chain (sg)

本文介绍了一种通过将环形结构转化为链式结构的方法来求解SG值的问题,并提供了具体的C++实现代码。该方法适用于解决特定类型的组合游戏问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

http://acm.hdu.edu.cn/showproblem.php?pid=3980

求sg值。

一开始被第二个样例卡住了,读了好几遍题才发现它初始是个环。

这样就可以先把它变成链,然后在链上枚举取m个连续点,每次都可以将这条链分成两部分,相当于两个子游戏。对于一个链,一共有n-m-i个子游戏对,用vis数组标记好这些子游戏对的异或值,最后就可以找出sg[n]。

这算是我做的第三种类型求sg值的题吧。

code:

#include<cstdio>
#include<cstring>
int sg[ 1001], m ;
int mex( int n){
     if(sg[n]!=- 1)    return sg[n] ;
     if(n-m< 0){
        sg[n] =  0 ;
         return  0 ;
    }
     bool vis[ 1001] ;
     int i ;
    memset(vis,  falsesizeof(vis)) ;
     for(i= 0; i<=n-m-i; i++)
        vis[mex(i)^mex(n-m-i)] =  1 ;
     for(i= 0; vis[i]; i++) ;
    sg[n] = i ;
     return sg[n] ;
}
int main(){
     int T, t, i, j, n ;
    scanf( " %d ", &T) ;
     for(t= 1; t<=T; t++){
        memset(sg, - 1sizeof(sg)) ;
        scanf( " %d%d ", &n, &m) ;
        printf( " Case #%d:  ", t) ;
         if(n<m){
            printf( " abcdxyzk\n ") ;
             continue ;
        }
         if(!mex(n-m))   printf( " aekdycoin\n ") ;
         else        printf( " abcdxyzk\n ") ;
    }
     return  0 ;} 

转载于:https://www.cnblogs.com/xiaolongchase/archive/2012/05/05/2484597.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值