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;
}
  • 10
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
2024日历A4纸打印版免费的情况可能有以下几种原因。 首先,随着技术的进步和发展,电子设备的普及程度越来越高。到2024年,越来越多的人可能会使用电子设备,例如智能手机、平板电脑等,来管理和查看日程安排。因此,传统的打印纸质日历可能会逐渐减少需求。为了适应这一变化,不少公司或机构可能会将2024年的日历以电子版的形式提供,免费供用户下载和打印。 其次,可能会有一些组织、机构或者企业愿意为了市场宣传目的免费提供纸质日历。这样的行为可以增加品牌的知名度和曝光度,吸引更多的人关注和注意到他们的产品或服务。通过将纸质日历免费提供给大众,他们可以在人们使用这些日历的过程中,不断地提醒和宣传自己的品牌信息,从而达到宣传效果。 最后,政府或社会组织也可能在特殊情况下提供免费的纸质日历。例如,在某些公共假期、纪念日或大型活动期间,政府可能会出资生产和发放特殊主题的日历,以丰富人们的生活和增强节日氛围。这种提供免费日历的行为旨在促进社会团结和增进公众利益。 综上所述,2024年纸质日历A4纸打印版免费的可能性主要与技术发展、市场宣传和特殊情况相关。无论是电子版还是纸质版,免费提供日历的行为都有助于满足人们日常生活和工作中的需求,并在一定程度上给人们带来便利。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值