趣味编程:用LINQ求解八皇后问题

来源:互联网 发布:淘宝摇摇摇在哪 编辑:程序博客网 时间:2024/05/18 03:33
C#源码摘自CSDN论坛.NET技术贴:从n皇后问题看Linq的对算法思想的清晰表达力,原作者sp1234。
注:变量名及程序逻辑稍有改动,求解部分加上了注释。
 

C#代码

代码说明
  1. 代码中带两个参数的Queens函数(第16~29行)是求解八皇后问题的核心函数。
  2. 函数采用递归方式求解,其主体部分只包含一句LINQ语句,非常简洁。
  3. 参数r表示当前调用被用于寻找第r行皇后的位置。(任意两个皇后都不能处在同一行中,因此每一行最多只能有一个皇后)
  4. 参数maxCol表示棋盘的宽度。
  5. 函数返回一个两维数组,数组第一维表示各个解,而第二维则用于存放单个解中各个皇后的位置。
采用LINQ求解,解法固然清晰简洁,但同时也存在着不可调试、不易理解的缺点,为此以下特提供
 

可调试的Queens函数(完全不用LINQ的“传统”版本)

以备参考。
 

补记:F#版本

原创粉丝点击