残缺棋盘是一个2^k*2^个方格的棋盘,其中恰有1个方格残缺。图中给出,其中残缺部分用阴影表示。
这样的棋盘称为"三格板",残缺棋盘问题就是用这四种三格板覆盖更大的残缺棋盘。再次覆盖中要求:
(1)两个三格板不能重复。
(2)三格板不能覆盖残缺棋盘方格,但必须覆盖到其他所有的方格。
算法思路:
利用分治算法将棋盘细化,逐步解决,以4*4为例
首先判断残缺的位置在哪里,然后在中间填上对应的三格板,如在上图中间拼上三角板(4),变成下面这样
然后通过中间将其分成了4个2*2的小残缺棋盘,从而问题得以解决
4*4的分析过于简单,现在我们以8*8为例进行分析,能更清楚的理解这个例子中分治算法的思想
首先将三格板放置在中间,将其分4个小的4*4的残缺棋盘
通过红色线将其划分成4个4*4的残