博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
js算法:分治法-棋盘覆盖
阅读量:6696 次
发布时间:2019-06-25

本文共 686 字,大约阅读时间需要 2 分钟。

在一个 2^k * 2^k 个方格组成的棋盘中,若恰有一个方格与其他方格不同。则称该方格为一特殊方格,称该棋盘为一特殊棋盘。显然特殊方格在棋盘上出现的位置有 4^k 种情形。因而对不论什么 k>=0 。有 4^k 种不同的特殊棋盘。

下图所看到的的特殊棋盘为 k=2 时 16 个特殊棋盘中的一个。

在棋盘覆盖问题中,要用下图中 4 中不同形态的 L 型骨牌覆盖一个给定的特殊棋牌上除特殊方格以外的全部方格,且不论什么 2 个 L 型骨牌不得重叠覆盖。

易知,在不论什么一个 2^k * 2^k 的棋盘中,用到的 L 型骨牌个数恰为 (4^k-1)/3 。

用分治策略,能够设计解棋盘问题的一个简捷的算法。

当 k>0 时,将 2^k * 2^k 棋盘切割为 4 个 2^(k-1) * 2^(k-1) 子棋盘,例如以下图所看到的。

特殊方格必位于 4 个较小子棋盘之中的一个中,其余 3 个子棋盘中无特殊方格。

为了将这 3 个无特殊方格的子棋盘转化为特殊棋盘,我们能够用一个 L 型骨牌覆盖这 3 个较小的棋盘的汇合处。例如以下图所看到的。这 3 个子棋盘上被 L 型骨牌覆盖的方格就成为该棋盘上的特殊方格,从而将原问题化为 4 个较小规模的棋盘覆盖问题。递归的使用 这样的切割。直至棋盘简化为 1x1 棋盘。

附代码:

    New Document   
级数:
坐标X:
坐标Y:

你可能感兴趣的文章
【html】使用img标签和背景图片之间的区别
查看>>
JDK源码阅读(一) ArrayList
查看>>
Quartz1.8.5例子(六)
查看>>
leetcode524
查看>>
leetcode806
查看>>
(29)odoo的可用小图标
查看>>
MVC ViewBag传值
查看>>
通过面试题学习零散知识:Java面试题整理
查看>>
达成目标5步法则——雷达里奥/核聚
查看>>
可能是最简单的 区块链入门教程——阮一峰
查看>>
Linux中使用iptables开放特定端口
查看>>
AC日记——无线网络发射器选址 洛谷 P2038
查看>>
CentOS虚拟机通过主机网络上网
查看>>
ListView内容动态刷新
查看>>
秘密袭击「九省联考 2018」
查看>>
美团在线编程2016---字符串
查看>>
Android Layout XML属性
查看>>
Redis架构设计
查看>>
Programming Ability Test学习 1026. 程序运行时间(15)
查看>>
implicit和explicit的基本使用
查看>>