2024河南萌新联赛第五场 A日历游戏(SG函数)

2024-08-23 20:44

本文主要是介绍2024河南萌新联赛第五场 A日历游戏(SG函数),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目链接

SG函数讲解


思路:

两个人对弈,然后还不满足一些常见的博弈模型,直接上SG函数。简单总结一下:

博弈论里的局面,表示的是某个人在做出决策前面临的一个情形,必胜与必败态指的就是这个人在某个局面下做出最优选择能否获胜。

显然游戏结束时是必败态,因为这时候面临局面的人还没有做出决策就比赛结束了, 说明对方在上一回合做出决定后就已经获胜了。必胜态必定存在一个必败态,必败态后面全为必胜态,因为我们肯定要把必败态留给对方,如果能做到,那么当前状态就是必胜态,因此必胜态后面一定有一个必败态。同理,如果做不到,说明当前状态无论怎么选,都一定会把必胜态留给对手, 当前状态就是必败态,因此必败态后面全为必胜态。

m e x ( S ) mex(S) mex(S) 运算表示在一个自然数集合 S S S 中取出被包含在 S S S 中的最小的自然数,比如 m e x ( { 1 , 2 , 3 } ) = 0 , m e x ( { 0 , 1 , 3 } ) = 2 mex(\{1,2,3\})=0,mex(\{0,1,3\})=2 mex({1,2,3})=0,mex({0,1,3})=2。SG函数的函数值是将后继所有局面的SG函数值做 m e x mex mex 运算得到的 。必败态SG函数值为 0 0 0,必胜态SG函数非 0 0 0。对于同时进行的多个局面(也就是同时面临多个局面,每次只能选一个局面进行操作,最后要求所有局面都结束才算游戏结束),SG值等于这几个局面的SG函数值做异或运算(证明和 N I M NIM NIM 游戏有关)。


在这个题里,可以从后向前递推SG函数值,也可以从前往后记忆化搜索,后者稍微好写一点。在dfs的时候注意优先月份向后搜索,这样很快就能搜到结束状态并返回,从而释放空间,要不然会爆空间。

code:

#include <iostream>
#include <cstdio>
#include <set>
#include <vector>
using namespace std;vector<int> month{0,31,28,31,30,31,30,31,31,30,31,30,31};bool vis[30][20][40];
int win[30][20][40];
int SG(int y,int m,int d){if(y==24 && m==8 && d==1)return 0;//必败局面 if(vis[y][m][d])return win[y][m][d];else vis[y][m][d]=true;vector<int> mon=month;set<int> sg;if(y%4==0)mon[2]++;//	printf("%d %d %d\n",y,m,d);if(!(y==24 && m==7 && d>1) && d<=mon[m%12+1]){sg.insert(SG(y+(m==12),m%12+1,d));}if(d+1<=mon[m])sg.insert(SG(y,m,d+1));else if(m+1<=12)sg.insert(SG(y,m+1,1));else sg.insert(SG(y+1,1,1));for(int i=0;;i++)if(sg.find(i)==sg.end())return win[y][m][d]=i;
}int T,x,y,z;int main(){SG(0,1,1);cin>>T;while(T--){cin>>x>>y>>z;x-=2000;if(SG(x,y,z)==0)cout<<"NO\n";else cout<<"YES\n";}return 0;
}

这篇关于2024河南萌新联赛第五场 A日历游戏(SG函数)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1100451

相关文章

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

游戏闪退弹窗提示找不到storm.dll文件怎么办? Stormdll文件损坏修复技巧

《游戏闪退弹窗提示找不到storm.dll文件怎么办?Stormdll文件损坏修复技巧》DLL文件丢失或损坏会导致软件无法正常运行,例如我们在电脑上运行软件或游戏时会得到以下提示:storm.dll... 很多玩家在打开游戏时,突然弹出“找不到storm.dll文件”的提示框,随后游戏直接闪退,这通常是由于

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串