Remove ads
来自维基百科,自由的百科全书
騎士巡禮(英語:Knight's tour)是指在按照国际象棋中骑士的规定走法走遍整个棋盘的每一个方格,而且每个网格只能夠经过一次。假若騎士能夠從走回到最初位置,則稱此巡禮為「封閉式巡禮」,否則,稱為「開放巡禮」。對於8*8棋盤,一共有26,534,728,821,064種封閉巡禮,有19,591,828,170,979,904種開放式巡禮。[1][2][3]
由骑士巡禮引申出了一个著名的数学问题 :骑士巡禮问题--找出所有的骑士巡禮路徑。編寫一個程式来找出骑士巡禮路徑經常在计算机系的学生的练习中出现。骑士巡禮问题的变种包括各种尺寸的棋盘甚至非正方形的棋盘。
已知的最早的骑士巡逻问题可以追溯到九世紀的古印度恰圖蘭卡。[5]
欧拉是最早研究骑士巡逻的数学家中的一员,而H·C·馮·汪斯道夫(H. C. von Warnsdorff)在1823年提出了第一个系统化解决骑士巡逻问题的方法——汪斯道夫规则。
在20世纪,一批乌力波的作家将这个问题用在了其它的地方。最明显的例子:乔治·佩雷克的小说《人生使用法》的章节顺序就是按照10×10棋盘的骑士巡逻路径来编排的。在2010年国际象棋世界冠军对抗赛的第六场比赛中,棋手维斯瓦纳坦·阿南德连续13次移动骑士(使用了两个骑士),在线评论员打趣地说阿南德试图在游戏过程中解决骑士巡逻问题。
骑士巡逻问题实际上是哈密顿路径问题的一种特殊形式,寻找骑士巡逻的闭巡逻路径的个数实际上也是哈密顿循环问题的一种特殊形式。但是和一般的哈密顿路径问题不同,骑士巡逻问题可以在线性时间内解决。[6]
用穷举法来寻找骑士巡逻路径适用于格数较小的棋盘,因为当方格数过多时,可能的路径过多。例如,8×8棋盘中大约有4×10^51种可能的路径。[11]如此大的运算量已经超出了现代计算机的运算能力。
利用分治法将棋盘分成很多小块,计算出每一小块中的所有可能路径,然后将这些小块合并再计算所有可能的路径。
汪斯道夫規律指在所有可走且未經過的方格中,騎士只可能走這個方格:從該格出发,騎士能跳的方格數最少;如果可跳的方格數相等,則從當前位置看,方格序号小的優先。依照這一規律往往可以找到一條路徑但並不一定能夠成功。
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.