博客
关于我
hdu_oj2176取(m堆)石子游戏(nim博弈)
阅读量:297 次
发布时间:2019-03-01

本文共 1350 字,大约阅读时间需要 4 分钟。

为了解决这个问题,我们需要分析Nim博弈的规则,确定先手是否能获胜,并提供获胜策略。Nim博弈的关键在于异或和的计算,如果异或和为0,先手必输;否则先手必赢。

方法思路

  • 输入处理:读取输入数据,每组数据由一个整数m和后面跟着m个非零正整数组成,直到m=0时结束。
  • 计算异或和:对于每一堆石子,计算所有堆石子数量的异或和k。如果k为0,先手必输,输出"No"。
  • 确定获胜策略:如果k不为0,先手必赢。对于每一堆石子,计算p = a_i ^ k。如果p小于a_i,表示从这堆石子中取出a_i - p个石子是一个有效策略。
  • 输出结果:输出"Yes"并列出所有有效策略。
  • 解决代码

    #include 
    #include
    #include
    #include
    #include
    using namespace std;int main() { vector
    a; while (true) { string line; getline(cin, line); if (line.empty()) continue; istringstream iss(line); int m; iss >> m; if (m == 0) break; vector
    parts; for (int i = 0; i < m; ++i) { int num; iss >> num; parts.push_back(num); } vector
    heaps(parts.begin(), parts.end()); ll k = 0; for (int num : heaps) { k ^= num; } if (k == 0) { cout << "No" << endl; } else { vector
    take_list; for (int num : heaps) { int p = num ^ k; if (p < num) { take_list.push_back(num); take_list.push_back(p); } } cout << "Yes"; for (int num : take_list) { cout << ' ' << num; } cout << endl; } } return 0;}

    代码解释

  • 输入处理:使用istringstream读取每一行输入,处理每组的m和后续的m个石子数量。
  • 异或和计算:遍历每一堆石子,计算所有石子数量的异或和k。
  • 策略判断:如果k为0,输出"No"。否则,遍历每一堆石子,计算p并判断是否需要采取策略。
  • 输出结果:根据策略结果输出"Yes"和相应的取法。
  • 这种方法确保了我们能够高效地解决问题,并在O(m)时间复杂度内完成所有计算。

    转载地址:http://kzlo.baihongyu.com/

    你可能感兴趣的文章
    OAuth2 Provider 项目常见问题解决方案
    查看>>
    OAuth2 vs JWT,到底怎么选?
    查看>>
    Vue.js 学习总结(14)—— Vue3 为什么推荐使用 ref 而不是 reactive
    查看>>
    oauth2-shiro 添加 redis 实现版本
    查看>>
    OAuth2.0_JWT令牌-生成令牌和校验令牌_Spring Security OAuth2.0认证授权---springcloud工作笔记148
    查看>>
    OAuth2.0_JWT令牌介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记147
    查看>>
    OAuth2.0_介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记137
    查看>>
    OAuth2.0_完善环境配置_把资源微服务客户端信息_授权码存入到数据库_Spring Security OAuth2.0认证授权---springcloud工作笔记149
    查看>>
    OAuth2.0_授权服务配置_Spring Security OAuth2.0认证授权---springcloud工作笔记140
    查看>>
    OAuth2.0_授权服务配置_三项内容_Spring Security OAuth2.0认证授权---springcloud工作笔记141
    查看>>
    OAuth2.0_授权服务配置_令牌服务和令牌端点配置_Spring Security OAuth2.0认证授权---springcloud工作笔记143
    查看>>
    OAuth2.0_授权服务配置_客户端详情配置_Spring Security OAuth2.0认证授权---springcloud工作笔记142
    查看>>
    OAuth2.0_授权服务配置_密码模式及其他模式_Spring Security OAuth2.0认证授权---springcloud工作笔记145
    查看>>
    OAuth2.0_授权服务配置_授权码模式_Spring Security OAuth2.0认证授权---springcloud工作笔记144
    查看>>
    OAuth2.0_授权服务配置_资源服务测试_Spring Security OAuth2.0认证授权---springcloud工作笔记146
    查看>>
    OAuth2.0_环境介绍_授权服务和资源服务_Spring Security OAuth2.0认证授权---springcloud工作笔记138
    查看>>
    OAuth2.0_环境搭建_Spring Security OAuth2.0认证授权---springcloud工作笔记139
    查看>>
    oauth2.0协议介绍,核心概念和角色,工作流程,概念和用途
    查看>>
    OAuth2.0四种模式的详解
    查看>>
    OAuth2授权码模式详细流程(一)——站在OAuth2设计者的角度来理解code
    查看>>