关于N皇后问题的思考

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)吧,不要生事。
在这里插入图片描述
却发现由于前面两个女人的骚操作,第三行已经再容不下别人,唉!太过分了,重新给第二行女子安排:

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值