bzoj1874 取石子游戏
2017-05-30 20:09
239 查看
暴力求SG函数即可。
注意最后输出字典序最小的解,并不一定要求sgi>res^sgi,因为一个状态的后继是可以有sgj>sgi的。
注意最后输出字典序最小的解,并不一定要求sgi>res^sgi,因为一个状态的后继是可以有sgj>sgi的。
#include<cstdio> #include<algorithm> using namespace std; const int maxn=15,maxa=1010; int vis[maxn],sg[maxa],a[maxn],b[maxn],n,m,mx; int main() { int res=0; scanf("%d",&n); for (int i=1;i<=n;i++) { scanf("%d",&a[i]); mx=max(mx,a[i]); } scanf("%d",&m); for (int i=1;i<=m;i++) scanf("%d",&b[i]); for (int i=1;i<=mx;i++) { for (int j=0;j<=m;j++) vis[j]=0; for (int j=1;j<=m&&i>=b[j];j++) vis[sg[i-b[j]]]=1; for (int j=0;;j++) if (!vis[j]) { sg[i]=j; break; } } for (int i=1;i<=n;i++) res^=sg[a[i]]; if (res) { printf("YES\n"); for (int i=1;;i++) for (int j=1;j<=m&&a[i]>=b[j];j++) if (sg[a[i]-b[j]]==(res^sg[a[i]])) { printf("%d %d\n",i,b[j]); return 0; } } else printf("NO\n"); }
相关文章推荐
- 【BZOJ 1874】 [BeiJing2009 WinterCamp]取石子游戏
- [BZOJ 1874] [BeiJing2009 WinterCamp] 取石子游戏 【博弈论 | SG函数】
- BZOJ 1874: [BeiJing2009 WinterCamp]取石子游戏(SG函数)
- bzoj1874: [BeiJing2009 WinterCamp]取石子游戏
- [BZOJ1874][BeiJing2009 WinterCamp]取石子游戏(博弈SG函数)
- 【BZOJ】【1874】取石子游戏
- [BeiJing2009 WinterCamp] bzoj1874 取石子游戏 [博弈论]
- [BZOJ1874][BeiJing2009 WinterCamp]取石子游戏
- bzoj 1874 取石子游戏 题解 & SG函数初探
- bzoj 1874 [BeiJing2009 WinterCamp]取石子游戏
- BZOJ 1874: [BeiJing2009 WinterCamp]取石子游戏 [Nim游戏 SG函数]
- 1874: [BeiJing2009 WinterCamp]取石子游戏 - BZOJ
- [BZOJ1874][BeiJing2009 WinterCamp]取石子游戏
- bzoj1874 [BeiJing2009 WinterCamp]取石子游戏 nim游戏 sg函数
- bzoj 1874: [BeiJing2009 WinterCamp]取石子游戏
- bzoj 1874: [BeiJing2009 WinterCamp]取石子游戏 Nim游戏+SG函数
- BZOJ 1874 取石子游戏 (NIM游戏)
- bzoj 1874 取石子游戏 题解 & SG函数初探
- 【博弈论】【SG函数】【枚举】bzoj1874 [BeiJing2009 WinterCamp]取石子游戏
- BZOJ1874: [BeiJing2009 WinterCamp]取石子游戏