hdu 2897(巴什博弈变形)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2897

转引:巴什博弈的变形:假设先取者为A,后取者为B,初始状态下有石子n个,除最后一次外其他每次取得石子个数必须在[pq]之间。

若当前石子共有=p+q* r个,则A必胜,必胜策略为:A第一次取q个,以后每次若BK个,A取(p+q-k)个,如此下去最后必剩下p个给B,所以A必胜。

=p+q)* r + left个(1< left <= pB必胜,必胜策略为:每次取石子活动中,若Ak个,则B去(p+q-k)个,那么最后剩下left个给A,此时left <= p,所以A只能一次去完,B胜。

=p+q* r + left个(< left <= q),则A必胜,必胜策略为:A第一次取t1<left  t <= p)个,以后每次Bk个,则A取(p+q-k)个,那么最后留下1< left  t <=pB,则A胜。

View Code
 1 #include<iostream>

 2 #include<cstdio>

 3 #include<cstring>

 4 using namespace std;

 5 

 6 int main(){

 7     int n,p,q;

 8     while(~scanf("%d%d%d",&n,&p,&q)){

 9         if(n%(p+q)==0){

10             puts("WIN");

11         }else {

12             int tmp=n%(p+q);

13             if(tmp<=p){

14                 puts("LOST");

15             }else

16                 puts("WIN");

17         }

18     }

19     return 0;

20 }

 

你可能感兴趣的:(HDU)