Lua程序设计(二)-八皇后问题

Eight-queen puzzle目标是把8个皇后合理的摆放在棋盘上,使得每个皇后之间都不能互相攻击。

对于这样的一道问题我们首先可以将国际象棋棋盘抽象为一个8*8的矩阵。目标就是把8个皇后放在这样一个矩阵中,使得他们互相之间不能攻击(横向,竖向,对角线)。

分析这个问题,不难发现当我们摆放一个棋子后,对应的问题规模即可摆放棋子的位置变小了,但是摆放棋子的思路确并不会改变都是需要我们去尝试当前行的所有列,然后根据题目限制条件判断是否可行。这自然而然的提醒我们采用递归的思路去解决问题。既然要用到递归,我们就需要确认终止条件,否则程序将无休止的运行下去,直到爆栈。这个问题的终止条件其实也比较容易想到,当我们要尝试的行大于棋盘的总行数时,程序应当停止,并输出相应的解决方案。 但是,这里会碰到一个问题,程序执行中代码是顺序执行的,而当我们确认某一列不能摆放棋子时,我们应当回溯到之前的条件下,这时就要用到回溯算法(BackTracking)来保证我们每次都能回退到相同的条件情况。 

确认了思路之后,附上相应的Lua代码来解决这个问题。

N = 8
    
function addqueen(a, n)
    if n > N then
        printsolution(a)  --所有的皇后已经放置好了
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Lua程序设计第4版》是一本非常经典的Lua编程书籍,它介绍了Lua程序设计的基本概念和技巧,并提供了大量的实例和练习,适合初学者和有一定编程基础的人阅读。 这本书的PDF版本非常方便,可以在电子设备上随时随地阅读。拥有PDF格式的书籍,读者可以通过搜索、书签、标注等功能,更好地管理和查找自己感兴趣的内容。此外,PDF版本还可以进行页面放大、缩小、翻转等操作,适应不同设备和阅读需求。对于学习Lua编程的人来说,这本书的PDF版本无疑是很有帮助的。 《Lua程序设计第4版》从基础语法、数据类型、运算符等内容开始介绍Lua的基础知识,然后逐步深入到表、函数、模块等高级特性,还介绍了面向对象编程和异常处理等更高级的主题。通过阅读这本书,读者可以系统地学习Lua的各种语言特性和编程技巧,掌握Lua编程的基本原理和方法。 在阅读过程中,读者可以参考书中的实例代码进行练习,并通过实践来加深对Lua编程的理解和掌握。此外,书中还提供了一些练习题,可以帮助读者巩固所学知识,培养编程思维和解决问题的能力。 总之,《Lua程序设计第4版》是一本很有价值的Lua编程书籍,提供了全面而深入的学习内容,适合想要学习Lua编程的读者阅读。PDF版本的书籍具有便携性和便捷性,非常方便读者随时随地进行学习。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值