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

相关文章

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

Python Counter 函数使用案例

《PythonCounter函数使用案例》Counter是collections模块中的一个类,专门用于对可迭代对象中的元素进行计数,接下来通过本文给大家介绍PythonCounter函数使用案例... 目录一、Counter函数概述二、基本使用案例(一)列表元素计数(二)字符串字符计数(三)元组计数三、C

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N

MySQL中REPLACE函数与语句举例详解

《MySQL中REPLACE函数与语句举例详解》在MySQL中REPLACE函数是一个用于处理字符串的强大工具,它的主要功能是替换字符串中的某些子字符串,:本文主要介绍MySQL中REPLACE函... 目录一、REPLACE()函数语法:参数说明:功能说明:示例:二、REPLACE INTO语句语法:参数

python中update()函数的用法和一些例子

《python中update()函数的用法和一些例子》update()方法是字典对象的方法,用于将一个字典中的键值对更新到另一个字典中,:本文主要介绍python中update()函数的用法和一些... 目录前言用法注意事项示例示例 1: 使用另一个字典来更新示例 2: 使用可迭代对象来更新示例 3: 使用

Python lambda函数(匿名函数)、参数类型与递归全解析

《Pythonlambda函数(匿名函数)、参数类型与递归全解析》本文详解Python中lambda匿名函数、灵活参数类型和递归函数三大进阶特性,分别介绍其定义、应用场景及注意事项,助力编写简洁高效... 目录一、lambda 匿名函数:简洁的单行函数1. lambda 的定义与基本用法2. lambda

Python 函数详解:从基础语法到高级使用技巧

《Python函数详解:从基础语法到高级使用技巧》本文基于实例代码,全面讲解Python函数的定义、参数传递、变量作用域及类型标注等知识点,帮助初学者快速掌握函数的使用技巧,感兴趣的朋友跟随小编一起... 目录一、函数的基本概念与作用二、函数的定义与调用1. 无参函数2. 带参函数3. 带返回值的函数4.

MySQL中DATE_FORMAT时间函数的使用小结

《MySQL中DATE_FORMAT时间函数的使用小结》本文主要介绍了MySQL中DATE_FORMAT时间函数的使用小结,用于格式化日期/时间字段,可提取年月、统计月份数据、精确到天,对大家的学习或... 目录前言DATE_FORMAT时间函数总结前言mysql可以使用DATE_FORMAT获取日期字段

Django中的函数视图和类视图以及路由的定义方式

《Django中的函数视图和类视图以及路由的定义方式》Django视图分函数视图和类视图,前者用函数处理请求,后者继承View类定义方法,路由使用path()、re_path()或url(),通过in... 目录函数视图类视图路由总路由函数视图的路由类视图定义路由总结Django允许接收的请求方法http