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

注:变量名及程序逻辑稍有改动,求解部分加上了注释。
 

C#代码

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

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

以备参考。
 

补记:F#版本

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值