• HDU 1850 Being a Good Boy in Spring Festival


    原题链接:点击此处

    思路:还是博弈论,可以参考前一篇的博客。

      我在看了尼姆博奕之后才明白前一个博客也可以使用异或和的方法判断奇异局势,因为奇异局势的亦或和为0。

      因此若当前面对的不是奇异局势,那么我只要令c-a+b即可。故若当c<a+b,那这个可就不能变,那么可以考虑a<c+b....

      (异或的规矩是,写出二进制码,如果相同则变为0,不同变为1)

     源代码:

    #include <iostream>
    #include <stdio.h>
    #include<cstring>
    using namespace std;
    int a[200];
    
    
    int main()
    {
        int sum;
        int n,tmp;
        while(~scanf("%d",&n),n)
        {
            sum=0;
            memset(a,0,sizeof(a));
            for(int i=1;i<=n;i++)
                scanf("%d",&a[i]);
    
            for(int i=1;i<=n;i++)
            {
                tmp=0;
                for(int j=1;j<=n;j++)
                {
                    if(i==j)
                        continue;
                    else
                        tmp^=a[j];
                }
                if(tmp<a[i])//使非奇异局势变为奇异局势的方法有多少
                    sum++;
            }
            printf("%d
    ",sum);
        }
        return 0;
    }
    View Code
  • 相关阅读:
    GCD
    SQLite
    将博客搬至CSDN
    Extjs 4 总结
    spring mvc 复杂参数注入
    7/12 聊天室结束
    7/10
    7/6一些知识点
    随便写写
    spring boot 入门操作(三)
  • 原文地址:https://www.cnblogs.com/gdvxfgv/p/5744268.html
Copyright © 2020-2023  润新知