N皇后问题

原创 2004年08月09日 17:35:00

题目:

由八皇后问题扩展开来,即n*n的棋盘上摆放n个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行、同一列或同一斜线上,问有多少种摆法。

分析:

  问题可以转化为12345...n 的满足某种条件(行已不等,列亦不等,只需设定其不在同一斜线上,即斜率不为 1 或-1 )的排列.

代码:

Private Sub queensn(ByVal n As Integer, ByRef result() As String) '计算n皇后问题的过程
Dim i As Long, J As Integer, k As Integer, number As Long, num As Long '循环变量
Dim FIT As Boolean '判定是否符合条件
Dim ALL(), out() As String '用于输出的数组
ReDim ALL(1 To n)
ReDim out(1 To n)
number = 1
Dim TEMP1 As Long, TEMP2 As Integer '进制转换中间变量
For i = 1 To n
number = number * i ' get n!
Next
For i = 1 To number ' 穷举n!种排列
ALL(1) = 1
TEMP1 = i
For J = 2 To n
TEMP2 = TEMP1 Mod J '混合进制
TEMP1 = TEMP1 / J
If TEMP2 = 0 Then
ALL(J) = J 'temp2为 0则放在最后
Else
For k = J To TEMP2 + 1 Step -1
ALL(k) = ALL(k - 1) ' temp2之后的元素后移一位
Next
ALL(TEMP2) = J 'temp2不为 0 则置于第temp2个元素前
End If
Next '至此得到12345...n的一个排列

FIT = True '初始化变量

'循环判断有否两个皇后存在互吃
For J = 1 To n
For k = n To 1 Step -1
If Not k = J Then
If ALL(k) - ALL(J) = J - k Or ALL(k) - ALL(J) = k - J Then
FIT = False
GoTo pass '跳出循环
End If
End If
Next
Next

If FIT Then '满足条件时
num = num + 1 '输出编号
ReDim Preserve result(1 To num)
For J = 1 To n
out(J) = String(n, StrConv("□", vbWide))
Mid(out(J), ALL(J), 1) = StrConv("Q", vbWide)
Next
result(num) = "第" & num & "种方法:" & vbCrLf & Join(out, vbCrLf) '输出第 num 种 n 个皇后摆放状态
End If
pass:
Next
End Sub

Private Sub Command1_Click()
Dim result() As String
queensn 9, result '九皇后
Open "d:/result.txt" For Binary As #1
Put #1, , Join(result, vbCrLf)
Close #1
MsgBox "ok"
End Sub

 

n皇后2种解题思路与代码-Java与C++实现

本文主要讲了n皇后问题的解题思路,并分别用java和c++实现了过程,最后,对于算法改进,使用了位运算。...
  • Evankaka
  • Evankaka
  • 2015年09月28日 08:37
  • 4260

回溯法及N皇后问题

回溯法是一种系统地搜索问题解答的方法。在搜索的过程中尝试找到问题的解,如果发现找不到了,就退一步,往上回溯(剪枝过程)。对于许多复杂问题和大规模问题都可以使用回溯法。 回溯法的基本思想是按照深度优先...
  • charles1e
  • charles1e
  • 2016年06月12日 15:55
  • 1176

Python实现N皇后问题

八皇后问题: 就是随机的在一个8*8的棋盘上,放置八个皇后,使其每个皇后的位置不在同一条直线上并且不在同一条对角线上。类似的可以扩展到n*n的棋盘上。 # -*- coding:utf-8 -*- i...
  • u014645717
  • u014645717
  • 2016年08月08日 10:58
  • 234

N皇后问题--回溯算法的经典实例

问题描述: 皇后是国际象棋中威力最大的棋子。在下面所示的棋盘上,皇后可以攻击位于箭头所覆盖位置的所有棋子。我们能不能把N个皇后放在棋盘(N×N)上,它们中的任何一个都无法攻击其余的皇后?请编写程序输出...
  • shengabc
  • shengabc
  • 2016年04月11日 16:50
  • 4498

深入N皇后问题的一个高效算法的详解

深入N皇后问题的一个高效算法的详解 author: liuzhiwei N皇后问题是一个经典的问题,在一个N*N的棋盘上放置N个皇后,每行一个并使其不能互相攻击(同一行...
  • hunyxv
  • hunyxv
  • 2017年02月23日 18:30
  • 1065

华为OJ之N皇后问题(C++代码)

1问题描述 N皇后问题,就是如何将国际象棋中的N个皇后放在N*N的棋盘上而不会互相攻击,是一种通过枚举,再递归、回溯的思想。2思路 以8皇后问题为例,可知在8*8二维数组中,每个点用data[i]...
  • chenloxiaoea
  • chenloxiaoea
  • 2015年12月10日 10:46
  • 2413

LintCode-N皇后问题

n皇后问题是将n个皇后放置在n*n的棋盘上,皇后彼此之间不能相互攻击。 给定一个整数n,返回所有不同的n皇后问题的解决方案。 每个解决方案包含一个明确的n皇后放置布局,其中“Q”和“.”分别表...
  • wangyuquanliuli
  • wangyuquanliuli
  • 2015年08月20日 19:49
  • 1444

N皇后问题:基于局部搜索策略的高效算法

基于局部搜索策略的高效算法,求解5000个皇后问题,单核时间控制在15分钟以内。代码中有打印棋盘形式的代码,可选择运行。在冲突检测部分,提供了两种方法,包括暴力循环方法和数组方法,大家可以用来参考学习...
  • qq_14809723
  • qq_14809723
  • 2017年12月25日 12:36
  • 117

算法分析之N皇后问题

因为这学期的算法分析课快要完了,也差不多进入复习阶段了,所以在这就把学习到的一些比较经典的算法拿出来晒晒,可能不是最好的,但怎么说也是为解决问题提供了一个思路。关于算法,有很多类型的问题,我在这里就拣...
  • nicolas_huan
  • nicolas_huan
  • 2017年03月28日 10:36
  • 206

N皇后问题递归与非递归解法

参考资料:http://www.cnblogs.com/yanlingyin/archive/2011/12/19/2292041.html
  • liuyongvs2009
  • liuyongvs2009
  • 2014年09月29日 15:36
  • 2410
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:N皇后问题
举报原因:
原因补充:

(最多只允许输入30个字)