当前位置: 首页 > article >正文

Nim游戏

文章目录

    • 题目描述
      • 输入格式
      • 输出格式
    • 结论
    • 程序代码

题目描述

给定 n 堆石子,两位玩家轮流操作,每次操作可以从任意一堆石子中拿走任意数量的石子(可以拿完,但不能不拿),最后无法进行操作的人视为失败。

问如果两人都采用最优策略,先手是否必胜。

输入格式

第一行包含整数 n。

第二行包含 n 个数字,其中第 i 个数字表示第 i 堆石子的数量。

输出格式

如果先手方必胜,则输出 Yes。

否则,输出 No。

结论

假设 n 堆石子,石子数目分别是a1, a2, …, an

  • a1 ^ a2 ^ ... ^ an = 0:先手必败
  • a1 ^ a2 ^ ... ^ an != 0:先手必败

程序代码

#include <iostream>
using namespace std;

int main()
{
    int n;
    cin >> n;
    int res = 0;
    while(n--) {
        int x;
        cin >> x;
        res ^= x;
    }
    if(res)  cout << "Yes" << endl;
    else  cout << "No" << endl;
    return 0;
}

http://www.kler.cn/a/229515.html

相关文章:

  • 使用 IDEA 开发一个简单易用的 SDK
  • DevOps落地笔记-15|混沌工程:通过问题注入提高系统可靠性
  • re:从0开始的CSS学习之路 1. CSS语法规则
  • 数论:修改数列
  • Spring Data Envers 数据审计实战
  • 编码安全风险是什么,如何进行有效的防护
  • Spring boot 集成redis
  • centos | vscode | 更新迭代太快了吧!
  • No matching client found for package name ‘com.unity3d.player‘
  • 一文简介Maven初级使用
  • Kafka下载(kafka和jdk、zookeeper、SpringBoot的版本对应关系)
  • [C++] 如何使用Visual Studio 2022 + QT6创建桌面应用
  • Kafka零拷贝技术与传统数据复制次数比较
  • VB.NET开发下拉多选功能
  • 『运维备忘录』之 Yum 命令详解
  • Droppy教程 | 轻量文件共享
  • Java List的合并与切分
  • YUM | 起源 | 发展 | 运行逻辑
  • 问题:能实现门到门的运输形式是() #笔记#媒体
  • 【工具使用】arm-gcc工具链安装