组合博弈 sg函数 Nim游戏的板子默写

news/2025/11/23 21:52:57/文章来源:https://www.cnblogs.com/zailihaiyidd/p/19261641

简单的取子用sg(x)==0 判断不就可以了吗!!!
所有游戏单个子游戏的思想

1.sg(x)有向无环图上的棋子游戏

每个棋子和它的出边都构成单独的有向无环图
通过一个棋子的所有后继节点我们可以得到这个点的sg
ans是所有点的sg之和用于判定先后手的必胜策略

#include <bits/stdc++.h>
using namespace std;
struct node
{int v,nv;
}e[100];
int h[100];int f[100];int idx=0;void add(int u,int v)//链式前向星建边 
{e[++idx]={v,h[u]};h[u]=idx;
}int sg(int x)
{if(f[x]!=-1) return f[x];set<int>s;for(int i=h[x];i;i++)//i!=0 就是有边 所有的后继 {s.insert(sg(i));}for(int i=0;;i++){if(s.count(i)==0) return f[x]=i;//记忆化缩短时间 }
}
int main()
{memset(h,0,sizeof(h));memset(f,-1,sizeof(f));int n;cin>>n;int uu,vv;for(int i=0;i<n;i++){cin>>uu>>vv;add(uu,vv);}int ans=0;for(int i=0;i<n;i++){ans^=sg(i); //别写成+}if(ans) cout<<"先手胜"<<endl;else cout<<"后手胜"<<endl;
}

2.sg(x)集合型的Nim

和普通的nim游戏是不一样的
这个也是多堆但是有取子规则

#include <bits/stdc++.h>
using namespace std;
int k[10];int kk;//取子规则 
int f[100];
int sg(int x)
{if(f[x]!=-1) return f[x];set<int>s;//一定牢记 for(int i=0;i<kk;i++){if(x>k[i]) s.insert(sg(x-k[i]));//条件判断别漏 不然你上哪里哭去 }for(int i=0;;i++){if(s.count(i)==0) return f[x]=i;//记忆化 }
}
int main()
{memset(f,-1,sizeof(f));//革命是否胜利取决于这里 cin>>kk;for(int i=0;i<kk;i++){cin>>k[i];//题目给我们的取子规则 }int m;//堆数 int ans=0;for(int i=0;i<m;i++){int tt;cin>>tt;//每堆石子有几个 ans^=sg(i);}if(ans) cout<<"先手胜"<<endl;else cout<<"后手胜"<<endl; 
}

3.普通的nim是多堆 每次从一堆中取任意个(棋盘的任意位置==一堆的个数)把替换也写一下怕自己忘了

#include <bits/stdc++.h>
using namespace std;
int main()
{int arr[100];int n;cin>>n;//有几堆 int ans=0;//0和任何数的^都是0 for(int i=0;i<n;i++){cin>>arr[i];//每堆的个数ans^=arr[i];}if(ans) cout<<"先手胜"<<endl;else cout<<"后手胜"<<endl;int count=0;for(int i=0;i<n;i++){if(ans^arr[i]<arr[i]) cout<<"可合法替换"<<endl;//做差是取出的个数 {arr[i]=ans^arr[i];count++;} } cout<<count<<endl;//合法替换的方案数目 for(int i=0;i<n;i++)//替换了之后是 {cout<<arr[i]<<" ";}}

4.台阶型的nim

一个台阶 一个位置放一个
后面不超过前面 (台阶的本质)
奇数位置的异或和==0吗

5.最后的碎碎念

所有结束位置是P 向前遍历所有规则是N
一个点向后看所有规则是N那他就是P
这样所有的简单博弈也难不倒我啦!!!

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

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

相关文章

详细介绍:Ribbon是如何与服务注册中心nacos交互的

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

Day46(16)-F:\硕士阶段\Java\课程代码\后端\web-ai-code\web-ai-project02\tlias-web-management

事务管理@Transactional(rollbackFor = {Exception.class})//事务管理的注解 - 默认出现RuntimeException才会回滚 @Override public void save(Emp emp) throws Exception{//1.保存员工的基本信息emp.setCreateTime(L…

完整教程:日本生活-东京新干线乘车经验-流程介绍

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

代码随想录算法训练营第三天:链表part01

代码随想录算法训练营第三天:链表part01**203.移除链表元素 ** leetcode链接:https://leetcode.cn/problems/remove-linked-list-elements/ 题目描述:给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所…

2025-07-21-Mon-T-RocketMQ

1. 核心功能 1.1 MQ介绍 RocketMQ基本组件Topic: 消息归类的基本单元 Queue: 消息队列 Producer Consumer ConsumerGroup: NameServer:可以理解为注册中心,负责更新和发现Broker Broker集群:Broker 可以有一个或…

第一章 简介

关于简介这一章,作者简单阐明了CPU,GPU过去的发展,以及它们的差异。除此之外,作者还引入了CUDA,介绍了CUDA的代码类型,以及全书的结构。 此章值得注意的点如下: 1、GPU上的晶体管数量超过CPU上的。 2、两设备之间…

2025-07-13-Sun-T-AI-LangChain4j

1. 认识AI 1.1 神经元介绍 黑马LangChain4j入门到实战项目: 项目地址 软件架构 前端:静态页面后端框架:SpringbootLangchain4j + Ollama持久化:本地文件存储对话记录 (resources/memory) 用户预约信息存储在内存(…

P24_现有网络模型的使用及修改

P24_现有网络模型的使用及修改24.1 VGG16网络模型: (1)打开pytorch(0.9.0)—torchvision.models—VGG(2)参数点击查看代码 pretrained (bool) – If True, returns a model pre-trained on ImageNet progress (bo…

20232403 2025-2026-1 《网络与系统攻防技术》实验六实验报告

1.实验内容 主要内容:使用ARP扫描和nmap进行主机发现与端口扫描、Vsftpd后门漏洞获得root权限、Samba命令注入漏洞获取系统访问、Java RMI反序列化漏洞建立Meterpreter会话、PHP CGI参数注入漏洞。 掌握Metasploit命令…

第二讲类神经网络训练不起来

第二讲类神经网络训练不起来 一.优化失败的原因梯度为0有可能是local minima 和saddle point 因为计算优化的终止条件是梯度为0,但有可能梯度为0仅是局部最小值local minima或鞍点saddle point(多维,在某些维度是最…

【计算机网络】深入浅出DNS:网络世界的地址簿与导航系统 - 教程

【计算机网络】深入浅出DNS:网络世界的地址簿与导航系统 - 教程2025-11-23 21:39 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !imp…

2025-01-24-Fri-T-如何做一个开源项目

创建和维护一个开源项目是一个非常有意义的工作,它可以帮助你与全球开发者合作,同时建立个人或团队的影响力。以下是详细步骤,帮你从零开始创建一个成功的开源项目。 1. 确定项目目标 解决实际问题:选择一个对你或…

利用大语言模型分析技术支持诈骗Facebook群组的网络犯罪研究

本文介绍了一项利用大语言模型分析Facebook上技术支持诈骗群组的研究,涉及38万条帖子的分类分析,揭示了网络犯罪服务的运作模式和最新趋势。网络犯罪与刑罚:我们在APWG eCrimes会议上关于技术支持诈骗Facebook群组的…

一些唐话

学OI学的言论均为转载 不保证言论可读你干嘛直接放 *3500 啊?!正经比赛里不是这样的!你应该先放两个简单签到,然后提升我的心态。偶尔给我送送强点的大样例,然后在那个我上厕所的时候跟我有神秘互动。最后在某个我…

2025-05-29-Thu-T-设计模式

目录1. 设计模式相关内容介绍1.1 设计模式概述1.2 UML类图类的表示方式类之间的关系表示方法1.3 软件设计原则1.1 开闭原则1.2 里氏代换原则1.3 依赖倒转/依赖倒置原则1.4 接口隔离原则1.5 迪米特法则1.6 合成复用原则…

2025-05-27-Tue-T-JVM

目录1 JVM与Java体系结构1.1 JVM 结构简图1.2 Java代码执行流程1.3 JVM的架构模型1.4 JVM的生命周期一、内存结构1. 程序计数器2. 虚拟机栈2.1 定义2.2 栈内存溢出2.3 线程运行诊断3. 本地方法栈4. 堆4.1 定义4.2 堆内…

11-28

今日掌握了 HashMap 的常用方法(put ()、get ()、containsKey ()),理解了键的唯一性,学会了遍历 Map 集合的两种方式(keySet、entrySet)。 明日计划学习多线程编程,重点理解线程的概念、创建方式(继承 Thread …

20232421 2025-2026-1 《网络与系统攻防技术》实验六实验报告

1.实践内容前期渗透主机发现 端口扫描 选做:也可以扫系统版本、漏洞等。Vsftpd源码包后门漏洞(21端口) SambaMS-RPC Shell命令注入漏洞(139端口) Java RMI SERVER命令执行漏洞(1099端口) PHP CGI参数执行注入漏…

20232315 2025-2026-1 《网络与系统攻防技术》实验六实验报告

20232315 2025-2026-1 《网络与系统攻防技术》实验六实验报告20232315 2025-2026-1 《网络与系统攻防技术》实验六实验报告 目录一、实验基本信息二、实验内容及要求三、实验过程3.1 前期渗透3.2 漏洞利用四、问题及解…

[CISCN 2022 华东北]duck WP

[CISCN 2022 华东北]duck WP[CISCN 2022 华东北]duck 一、题目来源 NSSCTF-Pwn-[CISCN 2022 华东北]duck二、信息搜集 通过 file 命令查看文件类型:通过 checksec 命令查看文件开启的保护机制:题目把 libc 文件和链接…