博弈论和sg函数

Nim游戏

题目链接:Nim游戏

先说结论:假设n堆石子,石子数分别为a1,a2,a3.....,则当a1^a2^a3^...^an=0时先手必败,否则先手必胜。

因为所表示的二进制位必定是成对出现的,根据性质 1 ^ 1 = 0 ,0 ^ 0 = 0 得出结论。(具体证明过程不再说明)

因此代码如下:

#include <bits/stdc++.h>
using namespace std;
int n;int main(){ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);cin>>n;int ans=0;for(int i=1;i<=n;i++){int x;cin>>x;ans^=x;}if(!ans)cout<<"No"<<"\n";else cout<<"Yes"<<"\n";return 0;
}

台阶-Nim游戏

题目链接:台阶-Nim游戏

首先给出结论:所有奇数阶的石子个数异或,如果异或和为0,那么先手必败,否则先手必胜。

因为从第一阶拿下来石子要取1次,第二阶拿下来要取2次。。。。。以此类推,所以可以看成第二阶有两堆石子,第三阶有三堆石子,因为两堆相同数量的石子异或和必然为0,而奇数阶的石子异或和为本身,所以只需将奇数阶的石子异或计算即可。

#include <bits/stdc++.h>
using namespace std;
int n;int main(){ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);cin>>n;int ans=0;for(int i=1;i<=n;i++){int x;cin>>x;if(i&1)ans^=x;}if(!ans)cout<<"No"<<"\n";else cout<<"Yes"<<"\n";return 0;
}

集合-Nim游戏

题目链接:集合-Nim游戏

SG函数

这道题目用到了SG函数,那么首先介绍一下什么是SG函数以及用法:

首先定义MEX集合表示集合中最小的没有出现的自然数,如MEX{1,2}=0,MEX{0,1,2}=3.

首先看左边这个图,我们把终点定义为sg(终点)=0;因为终点不能到达其他点,然后终点的前面一个点定义为sg(x)=1,因为后面有0,以此类推我们可以画出sg图。

那么SG函数具体的作用是什么呢?

首先终点的sg为0,意味着不能进行任何操作,在博弈论中意味着失败,那么当sg为0时,判负,相反,当sg不为0时,一定有一条路可以从该点走向sg(x)= 0,那么也就意味着如果先手不为0,那么一定可以让后手变为0.

接下来看题目,假设一堆有10个石子,我可以通过拿2个或5个使石子不能再拿,因此可以一个个枚举石子剩余的个数,如右图。接下来算出每个点的sg值,由图可知sg(10)=1,因此可以走到0让对手失败。

那么一堆是这样,n堆便用例题1的知识得:所有堆的sg异或和如果为0,先手必败,否则先手必胜。

#include <bits/stdc++.h>
using namespace std;
const int N =1e5+5;
int f[N],a[N];
int n,m;int sg(int x){if(f[x]!=-1)return f[x];//记忆化搜索unordered_set<int>s;for(int i=1;i<=m;i++){if(x>=a[i]){s.insert(sg(x-a[i]));}}for(int i=0;;i++){if(!s.count(i))return f[x]=i;}}int main(){ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);memset(f,-1,sizeof(f));cin>>m;for(int i=1;i<=m;i++){cin>>a[i];}int ans=0;cin>>n;for(int i=1;i<=n;i++){int x;cin>>x;ans^=sg(x);}if(!ans)cout<<"No"<<"\n";else cout<<"Yes"<<"\n";return 0;
}

拆分-Nim游戏

题目链接:拆分-Nim游戏

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/824573.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深入理解 pytest Fixture 方法及其应用

当涉及到编写自动化测试时&#xff0c;测试框架和工具的选择对于测试用例的设计和执行非常重要。在Python 中&#xff0c;pytest是一种广泛使用的测试框架&#xff0c;它提供了丰富的功能和灵活的扩展性。其中一个很有用的功 能是fixture方法&#xff0c;它允许我们初始化测试环…

HTML5漫画风格个人介绍源码

源码介绍 HTML5漫画风格个人介绍源码&#xff0c;源码由HTMLCSSJS组成&#xff0c;记事本打开源码文件可以进行内容文字之类的修改&#xff0c;双击html文件可以本地运行效果&#xff0c;也可以上传到服务器里面&#xff0c;重定向这个界面 效果截图 源码下载 HTML5漫画风格…

设计模式———单例模式

单例也就是只能有一个实例&#xff0c;即只创建一个实例对象&#xff0c;不能有多个。 可能会疑惑&#xff0c;那我写代码的时候注意点&#xff0c;只new一次不就得了。理论上是可以的&#xff0c;但在实际中很难实现&#xff0c;因为你无法预料到后面是否会脑抽一下~~因此我们…

【Pytorch】Conv1d

conv1d 先看看官方文档 再来个简单的例子 import torch import numpy as np import torch.nn as nndata np.arange(1, 13).reshape([1, 4, 3]) data torch.tensor(data, dtypetorch.float) print("[data]:\n", data) conv nn.Conv1d(in_channels4, out_channels1…

启明智显应用分享|基于ESP32-S3方案的SC01PLUS彩屏与chatgpt融合应用DEMO

今天将带大家真实体验科技与智慧的完美融合——SC01PLUS与ChatGPT的深度融合DEMO效果呈现。 彩屏的清晰显示与ChatGPT的精准回答&#xff0c;将为我们带来前所未有的便捷与高效。 SC01PLUS是启明智显基于ESP32-S3打造的一款3.5寸480*320分辨率的彩屏产品&#xff0c;您可以看…

【Git】git命令大全(持续更新)

本文架构 0.描述git简介术语 1.常用命令2. 信息管理新建git库命令更改存在库设置获取当前库信息 3.工作空间相关将工作空间文件添加到缓存区&#xff08;增&#xff09;从工作空间中移除文件&#xff08;删&#xff09;撤销提交 4.远程仓库相关同步远程仓库分支 &#xff08;持…

高版本Android studio 使用Markdown无法预览(已解决)

目录 概述 解决方法 概述 本人升级Android studio 当前版本为Android Studio Jellyfish | 2023.3.1 RC 2导致Markdown无法预览。 我尝试了很多网上的方法都无法Markdown解决预览问题&#xff0c;包括升级插件、安装各种和Markdown相关的插件及使用“Choose Boot Java Runtim…

一文了解OCI标准、runC、docker、contianerd、CRI的关系

docker和contanerd都是流行的容器运行时&#xff08;container runtime&#xff09;&#xff1b;想讲清楚他们两之间的关系&#xff0c;让我们先从runC和OCI规范说起。 一、OCI标准和runC 1、OCI&#xff08;open container initiative&#xff09; OCI是容器标准化组织为了…

利用动态规划优化10年投资回报:策略、证明与算法分析

利用动态规划优化10年投资回报&#xff1a;策略、证明与算法分析 a. 存在最优投资策略的证明b. 最优子结构性质的证明c. 最优投资策略规划算法设计d. 新限制条款下最优子结构性质的证明 在面对投资策略规划问题时&#xff0c;我们的目标是在10年后获得最大的回报。Amalgamated投…

牛客 NC205 跳跃游戏(三)【中等 贪心 Java,Go,PHP】

题目 题目链接&#xff1a; https://www.nowcoder.com/practice/14abdfaf0ec4419cbc722decc709938b 思路 参考答案Java import java.util.*;public class Solution {/*** 代码中的类名、方法名、参数名已经指定&#xff0c;请勿修改&#xff0c;直接返回方法规定的值即可*** …

Go 单元测试之Mysql数据库集成测试

文章目录 一、 sqlmock介绍二、安装三、基本用法四、一个小案例五、Gorm 初始化注意点 一、 sqlmock介绍 sqlmock 是一个用于测试数据库交互的 Go 模拟库。它可以模拟 SQL 查询、插入、更新等操作&#xff0c;并且可以验证 SQL 语句的执行情况&#xff0c;非常适合用于单元测试…

基于SpringBoot+Vue社区医院服务平台(源码+文档+包运行)

一.系统概述 随着信息技术在管理上越来越深入而广泛的应用&#xff0c;管理信息系统的实施在技术上已逐步成熟。本文介绍了社区医院信息平台的开发全过程。通过分析社区医院信息平台管理的不足&#xff0c;创建了一个计算机管理社区医院信息平台的方案。文章介绍了社区医院信息…

如何在Linux CentOS部署宝塔面板并实现固定公网地址访问内网宝塔

文章目录 一、使用官网一键安装命令安装宝塔二、简单配置宝塔&#xff0c;内网穿透三、使用固定公网地址访问宝塔 宝塔面板作为建站运维工具&#xff0c;适合新手&#xff0c;简单好用。当我们在家里/公司搭建了宝塔&#xff0c;没有公网IP&#xff0c;但是想要在外也可以访问内…

QAnything部署Mac m1环境

本次安装时Qanything已经更新到了v1.3.3&#xff0c;支持纯python安装。安装过程比较简单&#xff0c;如下&#xff1a; QAnything/README_zh.md at qanything-python-v1.3.1 netease-youdao/QAnything GitHub 首先需要用Anaconda3创建隔离环境&#xff0c;简要说明下Anaco…

春藤实业启动SAP S/4HANA Cloud Public Edition项目,与工博科技携手数字化转型之路

3月11日&#xff0c;广东省春藤实业有限公司&#xff08;以下简称“春藤实业”&#xff09;SAP S/4HANA Cloud Public Edition&#xff08;以下简称“SAP ERP公有云”&#xff09;项目正式启动。春藤实业董事长陈董、联络协调项目经理慕总、内部推行项目经理陈总以及工博董事长…

酒店水电能源计量管理系统

酒店水电能源计量管理系统是一种针对酒店行业设计的能源管理系统&#xff0c;旨在实现对水电能源的计量、监测和管理。本文将从系统特点、构成以及带来的效益三个方面展开介绍。 系统特点 1.多元化计量&#xff1a;该系统能够对酒店内的水、电能源进行多元化计量&#xff0c;…

软件项目总体测试计划(Word原件2024)

一、 前言 &#xff08;一&#xff09; 背景 &#xff08;二&#xff09; 目的 &#xff08;三&#xff09; 测试目标 &#xff08;四&#xff09; 适用范围与读者对象 &#xff08;五&#xff09; 术语与缩写 二、 软件测试实施流程 &#xff08;一&#xff09; 测试工作总体流…

2024年MathorCup数学建模C题物流网络分拣中心货量预测及人员排班解题文档与程序

2024年第十四届MathorCup高校数学建模挑战赛 C题 物流网络分拣中心货量预测及人员排班 原题再现&#xff1a; 电商物流网络在订单履约中由多个环节组成&#xff0c;图1是一个简化的物流网络示意图。其中&#xff0c;分拣中心作为网络的中间环节&#xff0c;需要将包按照不同流…

【Python基础】MySQL

文章目录 [toc]创建数据库创建数据表数据插入数据查询数据更新 个人主页&#xff1a;丷从心 系列专栏&#xff1a;Python基础 学习指南&#xff1a;Python学习指南 创建数据库 import pymysqldef create_database():db pymysql.connect(hostlocalhost, userroot, passwordr…

Maven多模块管理

Maven多模块管理 在了解怎么进行Maven多模块管理之前&#xff0c;先聊聊为什么要进行Maven多模块管理 为什么要Maven多模块管理&#xff1f; 在传统的单体架构开发下&#xff0c;一个项目中的依赖只需要使用一个pom.xml文件管理即可。但是随着微服务的流行&#xff0c;将原有…