C#源码摘自
CSDN论坛.NET技术贴:从n皇后问题看Linq的对算法思想的清晰表达力,原作者sp1234。
注:变量名及程序逻辑稍有改动,求解部分加上了注释。
C#代码
代码说明
- 代码中带两个参数的Queens函数(第16~29行)是求解八皇后问题的核心函数。
- 函数采用递归方式求解,其主体部分只包含一句LINQ语句,非常简洁。
- 参数r表示当前调用被用于寻找第r行皇后的位置。(任意两个皇后都不能处在同一行中,因此每一行最多只能有一个皇后)
- 参数maxCol表示棋盘的宽度。
- 函数返回一个两维数组,数组第一维表示各个解,而第二维则用于存放单个解中各个皇后的位置。
采用LINQ求解,解法固然清晰简洁,但同时也存在着不可调试、不易理解的缺点,为此以下特提供
可调试的Queens函数(完全不用LINQ的“传统”版本)
以备参考。