N皇后问题
题目:输入整数n,要求n个国际象棋的皇后,摆在n*n的棋盘上,不能互相攻击,输出全部方案。
eg.
Input: 4
OutPut: (1,2) (2,4) (3,1) (4,3)
(1,3) (2,1) (3,4) (4,2)
介绍
初做此题,由于没有玩过国际象棋(chess),很是尴尬,于是查了国际象棋的规则,详细内容如下:国际象棋
以上超链接对应网站和下面的图片均来自维基百科
其中王后queen最为强大,横竖对角线均可以走,步长不限。
要使王后们不相互攻击,发生甄嬛传里面的那些事情,就要把这些女人们妥善安排,否则很容易出幺蛾子。
那么,如何写这个程序呢?
首先,我们人工模拟一下,以4 × \times × 4的方形矩阵为例,按理说应该是4个皇后。
步骤
首先从第一行第一列开始(假设左上角为第一行第一列)开始,从上到下,从左到右遍历。(1,1)处为第一个可行皇后,到第二行,发现(2,1)不行(同一列),(2,2)不行(对角线),先把这老女人放在(2,3)吧,不要生事。
却发现由于前面两个女人的骚操作,第三行已经再容不下别人,唉!太过分了,重新给第二行女子安排: