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

重庆网站建设吧html5下载教程

重庆网站建设吧,html5下载教程,360搜索建站公司,国家免费技能培训官网目录 1 基础知识2 模板3 工程化 1 基础知识 (一) Nim游戏: n n n堆物品,每堆有 a i a_i ai​个,两个玩家轮流取走任意一堆的任意个物品,但不能不取。取走最后一个物品的人获胜。 结论:如果这n…

目录

  • 1 基础知识
  • 2 模板
  • 3 工程化

1 基础知识

(一)
Nim游戏: n n n堆物品,每堆有 a i a_i ai个,两个玩家轮流取走任意一堆的任意个物品,但不能不取。取走最后一个物品的人获胜。

结论:如果这n个数异或之和为0,则先手必败,否则先手必胜。
代码表示为,

#include <iostream>using namespace std;int main() {int n;cin >> n;int res = 0;while (n--) {int x;cin >> x;res = res ^ x;}if (res) puts("Yes");else puts("No");return 0;
}

(二)
集合Nim游戏:在Nim游戏的基础上,对每次取走的石子做了限制,每次取走的石子数必须在集合 S S S内。判断是否先手必胜。

抽象建模为,
有向图游戏和SG函数:在一个有向无环图中,只有一个起点,上面有一个棋子,两个玩家轮流沿有向边推动棋子,不能走的玩家判负。

定义mex函数的值为,不属于集合S中的最小非负整数,即:
m e x ( S ) = m i n { x } ( x ∉ S , x ∈ N ) mex(S)=min\{x\} \ (x\notin S, x\in N) mex(S)=min{x} (x/S,xN)
例如mex({0,2,3}) = 1, mex({1,2}) = 0。

对于状态 x x x和它的所有 k k k个后继状态 y 1 , y 2 , ⋯ , y k y_1,y_2,\cdots,y_k y1,y2,,yk,定义SG函数:
S G ( x ) = m e x { S G ( y 1 ) , S G ( y 2 ) , ⋯ , S G ( y k ) } SG(x)=mex\{SG(y_1), SG(y_2), \cdots, SG(y_k)\} SG(x)=mex{SG(y1),SG(y2),,SG(yk)}

而对于由n个有向图组成的组合游戏,设它们的起点分别为 s 1 , s 2 , ⋯ , s n s_1,s_2,\cdots,s_n s1,s2,,sn,则有定理:当且仅当这 n n n个数 S G ( s 1 ) , S G ( s 2 ) , ⋯ , S G ( s n ) SG(s_1),SG(s_2),\cdots,SG(s_n) SG(s1),SG(s2),,SG(sn)的异或和不为0时,这个游戏是先手必胜的,否则,是先手必败的。

C++代码如下,

#include <iostream>
#include <unordered_set>
#include <cstring>using namespace std;const int N = 110, M = 1e4 +10;
int n, m;
int s[N]; //每次可以取的石子数目
int f[M]; //这堆有x个石子,求sg[x]的值int sg(int x) {if (f[x] != -1) return f[x];unordered_set<int> S;//x能走到的结点的sg函数值for (int i = 0; i < n; ++i) {if (x - s[i] >= 0) S.insert(sg(x-s[i]));}for (int i = 0; ; ++i) {if (S.count(i) == 0) {f[x] = i;break;}}return f[x];
}int main() {cin >> n;for (int i = 0; i < n; ++i) cin >> s[i];int res = 0;memset(f, -1, sizeof f);cin >> m;while (m--) {int x;cin >> x;res ^= sg(x);}if (res) puts("Yes");else puts("No");return 0;
}

2 模板

暂无。。。

3 工程化

题目1:拆分Nim游戏,取走一堆,放回两堆规模更小的石子。

解题思路:重点在于如何确认某一堆的sg值,这样考虑遍历两堆规模更小的石子,就是它的下一步状态,求得它们的sg值,进行mex操作,即可得到这堆石子的sg值。

C++代码如下,

#include <iostream>
#include <unordered_set>
#include <cstring>using namespace std;const int N = 110;int n;
int f[N]; //sg值int sg(int x) {if (f[x] != -1) return f[x];//x可以走到的状态的sg值unordered_set<int> S;for (int i = 0; i < x; ++i) {for (int j = 0; j <= i; ++j) {S.insert(sg(i) ^ sg(j));}}//mex操作for (int i = 0; ; ++i) {if (!S.count(i)) {return f[x] = i;}}
}int main() {memset(f, -1, sizeof f);cin >> n;int res = 0;for (int i = 0; i < n; ++i) {int x;cin >> x;res ^= sg(x);}if (res) puts("Yes");else puts("No");return 0;
}
http://www.yayakq.cn/news/26274/

相关文章:

  • 上海网站建设报价书广州公司网站
  • 如何建设网站步骤营销型企业网站核心
  • 网站标题的关键字怎么写个人简介网站源码
  • 网站进度条特效网站首页布局的设计
  • 昆明网站建设咨询seo站长综合查询工具
  • 工业设计网站免费dede网站管理系统演示
  • 新乡网站建设waterseo福州网站定制公司
  • 建网站建设的基本流程公司注册地址变更需要什么资料
  • 福州市建设工程材料价格管理系统网站外贸怎样找到精准客户
  • 白云区建设局网站邯郸科技有限公司
  • 网站开发 超速云服装高级定制品牌
  • 天津专业网站建设wordpress多重筛选页面
  • 建设广告网站费用网站文件大小
  • jsp网站怎么做辽宁建设工程信息网官网新网站入口
  • 企业网站需求方案百度小程序官网
  • 网站开发合作协议书帮别人做网站进了看守所
  • 东莞活动网站设计模板阿里巴巴个人网站怎么做
  • 顺德电子画册网站建设在中国备案的网站服务器
  • 公司网站建设怎么做账春雨直播视频观看完整版
  • 做企业网站进行推广要多少钱站长工具如何使用
  • 自己这么做网站网站建设公司教程
  • 网站设计维护员优化 保证排名
  • 网站访问跳出率seo优化与推广招聘
  • 网站优化的重要性代还软件开发
  • 鲅鱼圈做网站网工资页多少钱一个月百度升级最新版本下载安装
  • 新手搭建论坛己做网站佛山技术支持 禅城企业网站
  • 江山市建设局网站网络营销环境的分析主要是
  • 网站需要收集什么建站资源漳州网站建设求职简历
  • 工厂弄个网站做外贸如何处理天元建设集团有限公司欠款
  • 网站推广排名优化网站制作公司兴田德润简介