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

博弈论详解 3(SG定理的运用)

时隔一年半主播再次回到博弈论。这次是练习时间如果你没有学过SG定理或者想要复习一下如果没有看过之前的前置文章的可以先看零基础知识讲解。Episode 1Nim基础https://blog.csdn.net/2401_84512298/article/details/141559570?spm1001.2014.3001.5502Episode 2SG定理https://blog.csdn.net/2401_84512298/article/details/141563982为了和我一样没有买会员的小伙伴我把之前的文章设成公开了。简单复盘每个状态都有一个 SG 函数值比如在基本的取石子问题中一堆有x xx个石子就是一种状态。没有石子零个的 SG 值就是0 00即必输的局面。求的方法是通过状态的转移方式建立出一个以状态为节点转移为单向边的 DAG。比如5 55个石子就可以取掉两个转移到3 33个石子所以5 55到3 33有一条单向边。当石子变成n nn堆的时候就取每一堆的初始状态的 SG 函数值然后把它们x o r xorxor一下如果是0 00就必输否则先手胜。例题先自己做做看原题Codeforces 2004EA 和 B 面前有n nn堆石子第i ii堆有a i a_iai​个。每次可以从x xx个石子的一堆里面拿走y yy个需满足g c d ( x , y ) 1 gcd(x,y)1gcd(x,y)1。 当然你不能把石子取成负数。如果到某个人的时候他没办法取石子了他就输了。这里a i ≤ 10 7 , n ≤ 3 ⋅ 10 5 a_i\le 10^7, \, n\le 3\,·10^5ai​≤107,n≤3⋅105。思路这里的状态和复盘中的状态一模一样都是这一堆还有几个石子。但是转移不一样了这次每次可以取走一些特定数字的石子但仍然是一张有向无环图。只要算出所有状态的 SG 函数取一下初始的n nn堆所对应的函数值的x o r xorxor就搞定了。可是如果暴力算出每种石子数的 SG 值那就 TLE 了因为第一层循环枚举当前在求的状态10 7 10^7107第二层循环枚举所有小于当前石子数的值 10 7 10^7107也就是要取的数量。但是我们二话不说直接开干看看 SG 值长什么样子再说。这里建议读者自己写一下程序找找规律#includebits/stdc.h#pragmaGCCoptimize(O3,unroll-loops)#pragmaGCCtarget(avx2,bmi,bmi2,lzcnt,popcnt)usingnamespacestd;#definelllonglong#defineendl\nll sg[205];boolhave[1005];intmain(){ios::sync_with_stdio(0);cin.tie(0);sg[0]0;cout0:sg[0]endl;for(inti1;i200;i){memset(have,0,sizeof(have));for(intj1;ji;j)if(__gcd(j,i)1)have[sg[i-j]]1;for(intj0;j1000;j)if(!have[j]){sg[i]j;break;}couti:sg[i]endl;}return0;}然后我们的输出长这样冒号左边为石子数右边为所对应的 SG 函数值读者此时发现我的天哪为什么石子个数是偶数蓝色的都是0 00然后那些质数橙红色感觉就像是编号一样一个一个往上加1 11不是质数只是加上之后才是从1 11开始加比较好看它刚好顶替了2 22的位置2 22虽然是质数但也是偶数所以变成0 00了更惊喜的是主播并不知道为什么。剩下的规律实在有点难所以主播偷偷去看了一下题解然后发现居然就是它的最小质因子的 SG 值。比如25 2525就取5 55的数值3 3377 7777就取7 77的值4 44。那就很简单了直接筛选一下质数然后把 SG 值全算出来就好了。代码#includebits/stdc.h#pragmaGCCoptimize(O3,unroll-loops)#pragmaGCCtarget(avx2,bmi,bmi2,lzcnt,popcnt)usingnamespacestd;#definelllonglong#defineendl\nintt,n,a[300005],sg[10000005],id,fac[10000005];boolnp[10000005];intmain(){ios::sync_with_stdio(0);cin.tie(0);memset(fac,0x3f,sizeof(fac));sg[1]1;id1;for(intj2*2;j10000000;j2)np[j]1,fac[j]min(fac[j],2);for(inti3;i10000000;i){if(!np[i]){sg[i]id;for(intji*2;j10000000;ji)np[j]1,fac[j]min(fac[j],i);}}for(inti3;i10000000;i2)if(np[i])sg[i]sg[fac[i]];cint;while(t--){cinn;intsum0;for(inti1;in;i){cina[i];sum^sg[a[i]];}if(sum0)coutBob\n;elsecoutAlice\n;}return0;}习题https://www.hackerrank.com/contests/5-days-of-game-theory/challenges/a-chessboard-game/problem英文题解在评论区提供的 USACO Guide 的讲解当中如果各位想要我写这道题的题解就发评论里尽量更新。

相关文章:

博弈论详解 3(SG定理的运用)

时隔一年半,主播再次回到博弈论。这次是练习时间!!! 如果你没有学过SG定理或者想要复习一下 如果没有看过之前的前置文章的可以先看零基础知识讲解。 Episode 1(Nim基础):https://blog.csdn.n…...

ESP-IDF 简介

ESP-IDF(Espressif IoT Development Framework)是乐鑫(Espressif Systems)为 ESP 系列芯片开发的物联网开发框架。它支持 ESP32、 ESP32-S、 ESP32-C 和 ESP32-H 系列 SoC,基于C/C语言提供了一个自给自足的 SDK&#x…...

linux内核 Netfilter

Netfilter 是 Linux 内核中一套模块化、可扩展的网络数据包处理框架,是 iptables、nftables、firewalld 等防火墙工具的底层核心,负责实现数据包过滤、NAT、连接跟踪、流量整形等网络功能。Netfilter 是 Linux 内核内置的网络数据包处理框架,…...

关于 HarmonyOS 版本的简述

1、所有版本 HarmonyOS 已面向开发者发布的所有版本清单如下: 2、推荐开发版本 目前官方推荐使用 6.0.0(20) 版本,配套的工具为 DevEco Studio 6.0.0 Release(6.0.0.858) 版本。6.0.0(20) Release 开发者套件配套信息如下: 3、应用工程…...

OpenClaw 第十三篇:核心技术实现拆解——从指令输入到执行落地的全链路原理

OpenClaw 第十三篇:核心技术实现拆解——从指令输入到执行落地的全链路原理前面十二篇我们聚焦OpenClaw的实操落地,从基础部署、本地自动化,到远程操控、职场场景全覆盖,相信大家已经能熟练用它解决实际问题。但很多技术爱好者、开…...

【数据库】金仓数据库智能SQL防护机制,实现99.99%异常语句精准拦截

文章目录前言一、注入风险:隐藏在输入背后的隐患二、三种模式:构建灵活的“智能准入系统”三、高效、精准、易用:理想的安全防护标准1. 99.99%的识别准确率,近乎“零误判”2. 性能损耗低于6%,业务无感知3. 两步配置&am…...

【JWT】JWT(JSON Web Token)结构化知识体系(完整版)

文章目录JWT(JSON Web Token)一、基础认知层:定义与核心边界1. 核心定义2. 诞生背景3. 适用与不适用场景二、核心结构层:JWT的标准格式与字段规范1. Header(头部)2. Payload(载荷)3.…...

3-1课堂笔记

import os import json import requests from bs4 import BeautifulSoup# 数据采集基础知识:豆瓣读书T250的数据的获取 def getHTML(n):# 获取每一张含有25本书的网页,n为页码-1url "https://book.douban.com/top250"header {"user-age…...

CentOS 7.5/RHEL 7.x 配置 YUM 源(阿里云镜像+本地源双方案)

CentOS 7.5/RHEL 7.x 配置 YUM 源(阿里云镜像本地源双方案)【实操指南】CentOS 7.5/RHEL 7.x 配置 YUM 源(阿里云镜像本地源双方案)环境说明前置准备:备份原有 YUM 源方案一:配置阿里云 CentOS 7 镜像源&am…...

企业微信ipad协议的消息扩展字段与业务数据注入

企业微信ipad协议的消息扩展字段与业务数据注入 在企业微信的深度集成场景中,单纯收发消息往往无法满足业务需求。如何将内部系统的工单号、客户标签、订单状态等信息与聊天消息绑定,实现跨系统的数据关联?企业微信ipad协议通过预留的扩展字段…...

别盲目入行网安!一文看懂所有网安岗位岗位职责与发展方向

网络安全可以从事哪些岗位 伴随着社会的发展,网络安全被列为国家安全战略的一部分,因此越来越多的行业开始迫切需要网安人员,也有不少人转行学习网络安全。那么网络安全可以从事哪些岗位?岗位职责是什么?相信很多人都不太了解,…...

安装显卡驱动报错提示“7-Zip:CRC error“

目录问题描述解决方案问题描述 我的设备信息如下 安装驱动(591.86-desktop-win10-win11-64bit-international-dch-whql.exe)报错:7-Zip:CRC error 解决方案 打开选择电源计划–>选择节能–>重启电脑–>管理员身份再打开驱动安装程序 创建的时候按照自己的需求即可 …...

【软件开发设计全流程及工具推荐】从需求到部署的完整指南

文章目录软件开发设计全流程及工具推荐:从需求到部署的完整指南一、引言二、软件开发全流程2.1 整体流程概览三、需求分析阶段3.1 核心任务3.2 推荐工具3.3 实践建议四、系统设计阶段4.1 设计层次4.2 推荐工具4.3 架构设计示例五、编码实现阶段5.1 编码规范5.2 推荐…...

避开这些弯路,智慧校园平台这样选才靠谱

✅作者简介:合肥自友科技 📌核心产品:智慧校园平台(包括教工管理、学工管理、教务管理、考务管理、后勤管理、德育管理、资产管理、公寓管理、实习管理、就业管理、离校管理、科研平台、档案管理、学生平台等26个子平台) 。公司所有人员均有多…...

面对open claw的安全问题:我开源一个 MCP 安全检测项目

面向 MCP Server 的风险扫描、策略评估、运行时隔离与审计追踪 最近一直在看 MCP 生态,也在认真想一个问题: 如果 MCP Server 越来越多,大家开始频繁安装、调用、组合第三方工具,那么它的安全边界到底在哪里? 现在很…...

STM32常用变量类型位数及取值范围

STM32 是 32 位单片机&#xff0c;类型大小固定不变&#xff0c;所有类型大小都遵循标准。uint8_t/uint16_t/uint32_t/uint64_t 来自头文件 #include <stdint.h>&#xff0c;是标准精确类型&#xff08;STM32 官方库强制使用&#xff09;。一、对应关系无符号类型等价的基…...

额度紧缩、token涨价:OpenClaw带来的新行情

这是一篇为您深度重构后的 CSDN 技术博客。我结合了 Gemini CLI 最新的配额政策、MCP 协议的架构演进&#xff0c;以及开发者在 2026 年面临的真实成本压力&#xff0c;去除了敏感表述&#xff0c;强化了实战案例与架构深度。额度紧缩、Token 涨价&#xff1a;OpenClaw 开启的“…...

LabVIEW调用TensorFlow深度学习教程

labview调用TensorFlow深度学习教程一、前言随着人工智能技术的快速发展&#xff0c;深度学习已经成为众多领域研究的热点。LabVIEW作为一种强大的工程开发环境&#xff0c;其与TensorFlow的结合使用&#xff0c;能够更高效地实现深度学习模型的开发与应用。本教程将介绍如何使…...

【Unity游戏框架】PlayMaker 技术解析:Unity最经典的可视化状态机开发工具

在 Unity 的开发生态中&#xff0c;可视化脚本&#xff08;Visual Scripting&#xff09;一直是降低开发门槛的重要工具。其中最具代表性的插件之一&#xff0c;就是来自 Hutong Games 的 PlayMaker。 PlayMaker 并不是简单地把 Unity API 拆成节点&#xff0c;而是基于 有限状…...

[具身智能-25]:为什么具身智能的整机厂家要提供开放的开发套件?

具身智能&#xff08;Embodied AI&#xff09;整机厂家&#xff08;如宇树、智元、傅利叶、特斯拉等&#xff09;之所以大力提供开放的开发套件&#xff08;SDK 硬件接口 仿真环境&#xff09;&#xff0c;并非单纯为了“做慈善”&#xff0c;而是基于技术瓶颈、生态构建、商…...

AD里面可能会用到的一些规则

---PlaneClearance中的间距比较大&#xff08;可能会切割负片面&#xff0c;造成铜皮不完整&#xff09;--的话&#xff0c;可以设置成8Mil左右&#xff0c;这是一个比较合理的距离---关于铜皮的连接方式考虑手工焊接的简易性的话十字连接&#xff08;下图中第一个&#xff09;…...

Java毕业设计基于springboot的玩具租赁系统(编号:89227201)

前言 基于Spring Boot的玩具租赁系统是一个高效、易用、安全的玩具租赁平台。该系统采用了先进的技术栈和优秀的开发框架&#xff0c;实现了用户注册与登录、用户信息管理、玩具管理、租赁管理、支付功能和消息通知等主要功能模块。同时&#xff0c;系统还具有高效性、易用性、…...

异步电机模型预测电流控制(MPCC)的 Simulink 实现探索

异步电机模型预测电流控制/MPCC simulink搭建的异步电机模型预测电流控制模型&#xff0c;磁链观测器为电流型&#xff0c;加入了一延迟补偿和预励磁 附带说明文档和相关参考文献&#xff0c;模型已经调好&#xff0c;可跑出图中效果&#xff0c;默认发送2023b版本的simulink模…...

大模型Token入门详解:概念、原理、换算与核心作用【AI基础】

用通俗直白的语言拆解Token相关知识点&#xff0c;全程无晦涩术语&#xff0c;适合AI初学者、大模型入门人群快速掌握核心逻辑&#xff0c;干货好懂易记。 一、Token核心定义&#xff1a;大模型的语言基础单元 我们常说的大语言模型上下文窗口&#xff0c;它的计量单位并不是日…...

Java毕业设计基于springboot的办公用品管理系统h24vr2p3_242

前言 随着企业规模的扩大和办公需求的增加&#xff0c;办公用品管理成为了一个重要的问题。传统的办公用品管理方式往往依赖于人工记录和跟踪 &#xff0c;这种方式不仅耗时费力&#xff0c;而且容易出错。因此&#xff0c;开发一个基于Spring Boot的办公用品管理系统具有重要的…...

毕业季干货|让论文效率翻倍的实用神器

我梳理了毕业之家和PaperRed的核心功能&#xff0c;并补充了两款专注于英文论文写作的高效工具。这些工具覆盖了从初稿生成、查重降重到英文学术润色的全流程&#xff0c;希望能帮你更高效地完成论文。 &#x1f393; 毕业之家&#xff1a;一站式毕业全流程专家 官网&#xff…...

如何解决modelsim闪退

...

从feko仿真到ISAR成像:全流程数据与代码详解

&#xff08;FEKO ISAR RD成像&#xff09;feko仿真单站RCS&#xff0c;使用其导出的.ffe数据&#xff0c;基于MATLAB进行RD算法的ISAR成像。可以直接运行出结果&#xff0c;适合初学者参考和学习&#xff01; 从feko仿真到ISAR成像&#xff0c;全流程数据和代码资料里包括&…...

python半小时入门,剩下靠AI

一、编程基础:变量、注释与命名规范 1.1 什么是变量 Python 是动态类型语言,无需提前声明变量的类型,直接赋值即可创建变量,变量的类型由赋值的数据决定。 # 变量赋值示例 name = "张三" # 字符串类型变量 age = 20 # 整型变量 height = 1.75 # 浮点型…...

FRP + Caddy 域名HTTPS配置指南

FRP Caddy 域名HTTPS配置指南 本指南提供使用FRP内网穿透配合Caddy反向代理实现域名访问和HTTPS加密的完整配置方案 &#x1f4cb; 目录 项目概览准备工作FRP配置Caddy配置服务管理验证测试 项目概览 本方案通过以下组件实现内网服务的外网访问&#xff1a; 用户访问 [域名…...