Hex棋,又叫六角棋,译作海克斯棋。据说这个游戏是约翰·纳什发明的。网上并没有太多介绍,第一次听说是在“中国大学生计算机博弈大赛”官网上。

棋盘为11×11的六边形小格子组成,它是一种两人添子类游戏(跟五子棋一样)。



它的游戏规则是:两人轮流下子,直到有一方用棋子沟通了两条边(比如先手沟通上下两边则胜利,后手沟通左右两边则胜利)

这是一个先手必胜的游戏

这是一个没有和棋的游戏(我认为这就是这个游戏的魅力所在,我们要证明的就是它到底是先手必胜还是先手必败)

如何证明这个游戏不可能和棋呢?

这个问题等价于“给定一个下满棋盘的Hex棋,必然能够找到一条线沟通两边”

实际上,对于一个平面图,要想隔断两条边必然要连接另两条边。这句话就是证明。

Hex棋显然是一个平面图,因为它的棋盘边没有交叉。

如何证明这个游戏先手必胜呢?

假设这个游戏后手必胜,那么先手从第一个子就模拟后手的必胜走法,从而先手必胜。推出矛盾,所以这个游戏先手必胜。

一言以蔽之,这个游戏是一个子越多越好的游戏。如果这个游戏子多反而是一种累赘,那么先手不一定必胜。

这是一个状态挺多的游戏,一般添子类游戏状态都很多。

它的状态数多达10的56次幂之多,比象棋(中象国象差不多)的10的40次幂还要多,但是感觉Hex比象棋简单多了。

下面统计一下添子类游戏(不包括围棋,围棋是添子吃子类游戏,象棋是不添子吃子类游戏)的状态数

0 0
1 0
2 13.0
3 2509.0
4 5183757.0
5 82109232401.0
6 1.2159122802580694e+16
7 1.6639278209049916e+22
8 2.0909903631443116e+29
9 2.4017537903420486e+37
10 2.5134265191388166e+46
11 2.390899903133055e+56
12 2.063808117058896e+67
13 1.6144415223776914e+79
14 1.1433467158917951e+92
15 7.324613324267597e+105
16 4.24188344332279e+120
17 2.2195633321116892e+136
18 1.0488619415965058e+153
19 4.4745506430191615e+170

python代码如下

def c(x, y):
ans = 1
for i in range(1, y + 1):
ans = ans * (x + 1 - i) / i
return ans for n in range(20):
print(n,sum([c(n * n, i) * c(n * n - i, i) for i in range(n * n // 2)]))

这个游戏的棋盘其实可以变成如下这样:

from  PIL import Image, ImageDraw

w = 30
n = 11 img = Image.new("RGBA", (w * n, w * n), "orange")
draw = ImageDraw.ImageDraw(img)
for i in range(n):
draw.line((w / 2, w / 2 + i * w, w / 2 + (n - 1) * w, w / 2 + i * w), 'black', 3)
draw.line((w / 2 + i * w, w / 2, w / 2 + i * w, w / 2 + (n - 1) * w), 'black', 3)
draw.line((w / 2, w / 2 + i * w, w / 2 + i * w, w / 2), "black", 3)
draw.line((w / 2 + (n - 1) * w, w / 2 + i * w, w / 2 + i * w, w / 2 + (n - 1) * w), "black", 3)
img.show()
img.save("haha.jpg")

Hex棋的更多相关文章

  1. win10 服务(系统默认服务)注册表

    ---恢复内容开始--- Windows Registry Editor Version 5.00 [HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services] ...

  2. quartus和modelsim中使用mif和hex文件

    .mif和.hex文件都是Quartus支持的数据文件格式,常被用作内存初始化文件.可是,M odelSim却不支持.mif文件,只支持.hex文件格式,这意味着如果你的设计采用了.mif文件 ,你的 ...

  3. [CareerCup] 17.2 Tic Tac Toe 井字棋游戏

    17.2 Design an algorithm to figure out if someone has won a game oftic-tac-toe. 这道题让我们判断玩家是否能赢井字棋游戏, ...

  4. 开源战棋 SLG 游戏框架设计思考(一)简介和游戏引擎

    战棋 SLG 游戏 SLG(Simulation Game)游戏是模拟游戏的简称.战棋类的SLG有两种:一种是 War Game 中的兵棋推演分支,常见的游戏有战争艺术3(TOAW3 — The Op ...

  5. 类型转换bin()、chr()、ord() 、int()、float()、str()、repr()、bytes()、tuple(s )、 list(s )   、unichr(x ) 、 ord(x )  、 hex(x )  、          type()数据类型查询

    1.bin() 将整数x转换为二进制字符串,如果x不为Python中int类型,x必须包含方法__index__()并且返回值为integer: 参数x:整数或者包含__index__()方法切返回值 ...

  6. 隔壁信概大作业xjb写——同化棋ATAXX

    话说泥萌北大信科啊,助教是有多懒...去年黑白棋今年同化棋,顺带打ai都不用自己写标程... 好吧..我知道泥萌重点在各种sb的辅助操作上..什么悲剧的可以随时暂停载入...有毒吧 [据说泥萌上课没讲 ...

  7. HEX文件格式和其校验算法

    这次我将在原来的基础上(http://www.cnblogs.com/libra13179/p/5787084.html)继续讲解HEX文件的格式 打开app_valid_setting_apply. ...

  8. quick cocos2d-x 入门---井字棋

    学习quick cocos2d-x 第二天 ,使用quick-x 做了一个井字棋游戏 . 我假设读者已经 http://wiki.quick-x.com/doku.php?id=zh_cn阅读了这个链 ...

  9. 使用Apache的Hex类实现Hex(16进制字符串和)和字节数组的互转

    包名称:org.apache.commons.codec.binary 类名称:org.apache.commons.codec.binary.Hex 1.字节数组(byte[])转为十六进制(Hex ...

随机推荐

  1. linux usb信息查看与调试

    lsusb cat /sys/kernel/debug/usb/devices T:  Bus=02 Lev=00 Prnt=00 Port=00 Cnt=00 Dev#=  1 Spd=12   M ...

  2. mybatis映射文件遇到的小问题

    mybatis的映射文件插入操作时: 如果对应的属性是String类型的,那么一定要做空串的判断. 比如注册的时候,如果需要向数据库中插入一条记录时,对应的字段没有给他赋值,这个String类型的值传 ...

  3. Objective-C:三种文件导入的方式比较

    三种文件导入的方式比较:   类的前项声明@class.import.include:   1.采用@class 类名的方式,它会告诉编译器有这么一个类,目前不需要知道它内部的实例变量和方法是如何定义 ...

  4. libcurl使用easy模式阻塞卡死等问题的完美解决---超时设置

    libcurl使用时疑难问题: 在使用libcurl时, jwisp发现, curl_easy_perform是阻塞的方式进行下载的, curl_easy_perform执行后,程序会在这里阻塞等待下 ...

  5. 【Todo】React & Nodejs学习 &事件驱动,非阻塞IO & JS知识栈:Node为主,JQuery为辅,Bootstrap & React为辅辅,其他如Angular了解用途即可

    JS知识栈:Node为主,JQuery为辅,Bootstrap & React为辅辅,其他如Angular了解用途即可 今天在学习ReactJS和NodeJS,看到关于ReactJS的这篇文章 ...

  6. [leetcode]Binary Tree Zigzag Level Order Traversal @ Python

    原题地址:http://oj.leetcode.com/problems/binary-tree-zigzag-level-order-traversal/ 题意: Given a binary tr ...

  7. Entity Framework泛型封装

    Entity Framework本身的增删改查其实 已经很方便了,不过做项目的时候用的多了也就觉得有点累了,每个业务实体基本上都涉及到到了增删改查这四个基本的要素,至于封装每个公司可能都不一样,接口, ...

  8. 如何在模板中引用参数类中的一个特定member

    C++模板有很多特性需要我们去挖掘,很多新的设计模式也都与模板使用相关,我们知道模板的一个基本特性就是可以根据传入的类型产生新的类型.围绕这个特性,可以衍生出很多的其它特性,比如自动为不同的类生成st ...

  9. 如何在Linux中发现IP地址冲突

    导读 你们都知道什么是IP地址,是吧?它们被分配给网络上的设备来代表它们.它们通过DHCP服务器分配并且会经常改变.现在有两种IP地址.动态的一种会经常改变(几天一次),而静态的就如它的名字那样是静态 ...

  10. ZOJ 2319 Beautiful People

    LIS.先按S降序升序再按B降序排序(如果B不按降序排序的话就会覆盖掉正解),然后再对B用O(nlog(n))的LIS求解就可以了.用d数组标记每个元素在上升序列中的位置,然后根据d倒着找id就可以了 ...