scala 解决8皇后问题

val n = 14
val Col = new Array[Boolean](n)
val Bevel1 = new Array[Boolean](n*2)
val Bevel2 = new Array[Boolean](n*2)
def col(y: Int) = !Col(y)
def bevel1(x: Int, y: Int) = !Bevel1(x-y+n-1)
def bevel2(x: Int, y: Int) = !Bevel2(x+y)
def dfs(x: Int): Int = if(x == n) 1 else Range(0, n).foldLeft(0)((a, b) => a + solve(x, b))
def solve(x: Int, i: Int): Int = {
    if(col(i) && bevel2(x, i) && bevel1(x, i)){
        Col(i) = true; Bevel1(x-i+n-1) = true; Bevel2(x+i) = true
        val ans = dfs(x+1)
        Col(i) = false; Bevel1(x-i+n-1) = false; Bevel2(x+i) = false
        ans
    }else 0
}
println("The number of queue is: " + n + " " + "result: " + dfs(0))

这个代码解决15后大约需要半分钟,16后3分钟

思路: 回溯。当走到某个地方后,先判断这个地方能不能走,就是判断该位置所在的行,列,斜是否有皇后。以为是一行一行往下走,该行上肯定没有皇后

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值