[SGU 223]Little Kings(状压DP)

该博客介绍了如何使用状态压缩动态规划(状压DP)解决一个棋盘问题:在N×N的棋盘上放置K个国王,使他们不相互攻击。博主分享了错误教训,即在以K为循环变量时可能导致计算错误,并提供了简洁的Pascal代码实现。文章还指出,当放置的国王数量超过棋盘格子总数一半时,问题无解。
摘要由CSDN通过智能技术生成

调了两天,发现是个极其2B的错误…………

[题目大意]

在N*N的棋盘上放K(这个万恶的K)个王,是他们相互之间不攻击,问有多少种方法。

[题目分析]

这个就是一个很经典的状压DP棋盘模型。就是说,我们想让他们不相互攻击,我们可以先用DFS求出保证在一行的情况下不相互攻击的情况,记录在一个数组里,用一个数来表示,他的二进制就表示了一个状态。

然后f[i,j,k]的含义就是前i行放了K个棋子,在第i行是第J个状态时的方案数。

然后就可以转移了,这个转移很好写,就不需要多说了。

我错的地方就是我想用K做循环变量,改变量的时候就在最后统计总和的地方出了问题。

还有一个地方需要注意的就是如果说放的个数比棋盘所有格子的一半还多的话,就肯定无解。

[代码(貌似我没有找到比我还精简的p的代码)]

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值