zoukankan      html  css  js  c++  java
  • HD 2177(威佐夫博弈 入门)

    取(2堆)石子游戏

    Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
    Total Submission(s): 1730    Accepted Submission(s): 1049


    Problem Description
    有两堆石子,数量任意,可以不同。游戏开始由两个人轮流取石子。游戏规定,每次有两种不同的取法,一是可以在任意的一堆中取走任意多的石子;二是可以在两堆中同时取走相同数量的石子。最后把石子全部取完者为胜者。现在给出初始的两堆石子的数目,如果轮到你先取,假设双方都采取最好的策略,问最后你是胜者还是败者。如果你胜,你第1次怎样取子? 
     
    Input
    输入包含若干行,表示若干种石子的初始情况,其中每一行包含两个非负整数a和b,表示两堆石子的数目,a和b都不大于1,000,000,且a<=b。a=b=0退出。
     
    Output
    输出也有若干行,如果最后你是败者,则为0,反之,输出1,并输出使你胜的你第1次取石子后剩下的两堆石子的数量x,y,x<=y。如果在任意的一堆中取走石子能胜同时在两堆中同时取走相同数量的石子也能胜,先输出取走相同数量的石子的情况.
     
    Sample Input
    1 2
    5 8
    4 7
    2 2
    0 0
     
    Sample Output
    0
    1
    4 7
    3 5
    0
    1
    0 0
    1 2
     
    如果(a - b) * gold == b则满足先手必败,其中gold = ( sqrt(5) + 1) ) / 2 = 1.618
    输出时先看是否能同时取相同数量的石子,即差值保持不变
    还有就是枚举差值,差值最小为1,最大为m-1,枚举满足这个差值的a和b,
    如果a == n则可以拿m使它成为b,
    如果a == m,这种可能不会存在,因为b就比最大的大了,
    如果b == n,则可以拿m使它成为a,
    如果b == m,则可以拿n,使他成为a
     1 #include <iostream>
     2 #include <cstring>
     3 #include <algorithm>
     4 #include <cstdio>
     5 #include <cmath>
     6 using namespace std;
     7 
     8 int main()
     9 {
    10     int n,m;
    11     while(scanf("%d%d", &n, &m) != EOF)
    12     {
    13         if(n == 0 && m == 0)
    14             break;
    15         if(n > m)
    16         {
    17             swap(n, m);
    18         }
    19         double gold = (sqrt(5) + 1)/2;
    20         int c = gold * (m - n);
    21         int a,b;
    22         if(c == n)
    23         {
    24             printf("0
    ");
    25         }
    26         else
    27         {
    28             printf("1
    ");
    29             printf("%d %d
    ", c, c + m - n);
    30             for(int i = 1; i <= m; i++)
    31             {
    32                a = i * gold;
    33                if(a == c)
    34                    continue;
    35                b = a + i;
    36                if(a == n)
    37                {
    38                    printf("%d %d
    ", a,b);
    39                }
    40                else if(b == n)
    41                {
    42                    printf("%d %d
    ",a, b);
    43                }
    44                else if(b == m)
    45                {
    46                    printf("%d %d
    ", a, b);
    47                }
    48             }
    49         }
    50     }
    51     return 0;
    52 }
    View Code
     
  • 相关阅读:
    initramfs扫描磁盘前改变磁盘上电顺序
    “井号键”用英语怎么说?
    syslog,rsyslog and syslog-ng
    glob (programming) and spool (/var/spool)
    CentOS 6.5语言包裁剪
    C​P​U​_​C​S​t​a​t​e​_​P​S​t​a​t​e and then ACPI on Wiki
    we are experimenting with a new init system and it is fun
    linux init->upstart->systemd
    微信浏览器内建的WeixinJSBridge 实现“返回”操作
    npm i node-sass 报错&npm 镜像切换
  • 原文地址:https://www.cnblogs.com/zhaopAC/p/5183246.html
Copyright © 2011-2022 走看看