



全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
7 数学与统计学院 全秋洪残缺棋盘问题残缺棋盘(defective chess board)是一个有2k2k个方格的棋盘,其中恰有一个方格残缺。图3给出k2时各种可能的残缺棋盘,其中残缺的方格用阴影表示。注意当k=0时,仅存在一种可能的残缺棋盘(如图3a所示)。事实上,对于任意k,恰好存在22k种不同的残缺棋盘。残缺棋盘的问题要求用3个方格的板(三格板)(triominoes)覆盖残缺棋盘(如图4所示)。在此覆盖中,两个三格板不能重叠,三格板不能覆盖残缺方格,但必须覆盖其他所有的方格。在这种限制条件下,所需要的三格板总数为(22k-1)/3。可以验证(22k-1)/3是一个整数。k为0的残缺棋盘很容易被覆盖,因为它没有非残缺的方格,用于覆盖的三格板的数目为0。当k=1时,正好存在3个非残缺的方格,并且这三个方格可用图4中的某一方向的三格板来覆盖。实际是要求用三格板覆盖n*n的方格棋盘,空出指定位置。图3 残缺棋盘图4 不同方向的三格板用分而治之方法可以很好地解决残缺棋盘问题。这一方法可将覆盖2k2k残缺棋盘的问题转化为覆盖较小残缺棋盘的问题。2k2k棋盘一个很自然的划分方法就是将它划分为如图5a所示的4个2k-12 k-1棋盘。注意到当完成这种划分后,4个小棋盘中仅仅有一个棋盘存在残缺方格(因为原来的2k2k棋盘仅仅有一个残缺方格)。首先覆盖其中包含残缺方格的2k-12 k-1残缺棋盘,然后把剩下的3个小棋盘转变为残缺棋盘,为此将一个三格板放在由这3个小棋盘形成的角上,如图5b所示,其中原2k2k棋盘中的残缺方格落入左上角的2k-12 k-1棋盘。可以采用这种分割技术递归地覆盖2k2k残缺棋盘。当棋盘的大小减为11时,递归过程终止。此时11的棋盘中仅仅包含一个方格且此方格残缺,所以无需放置三格板。图5 分割2k2k棋盘可以将上述分而治之算法编写成一个递归的C+函数TileBoard。该函数定义了一个全局的二维整数数组变量Board来表示棋盘。Board00表示棋盘中左上角的方格。该函数还定义了一个全局整数变量tile,其初始值为1。函数的输入参数如下:tr棋盘中左上角方格所在行。tc棋盘中左上角方格所在列。dr残缺方块所在行。dc残缺方块所在列。size棋盘的行数或列数。TileBoard函数的调用格式为TileBoard(tr,tc,dr,dc,size),其中size=2k。覆盖残缺棋盘所需要的三格板数目为(size2-1)/3。函数TileBoard用整数1到(size2-1)/3来表示这些三格板,并用三格板的标号来标记被该三格板覆盖的非残缺方格。令t(k)为函数TileBoard覆盖一个2k2k残缺棋盘所需要的时间。当k=0时,size等于1,覆盖它将花费常数时间d。当k0时,将进行4次递归的函数调用,这些调用需花费的时间为4t(k-1)。除了这些时间外,if条件测试和覆盖3个非残缺方格也需要时间,假设用常数c表示这些额外时间。可以得到以下递归表达式:可以用迭代的方法来计算这个表达式,可得t(k)=(22k)。程序 :残缺棋盘#include void TileBoard(int tr,int tc,int dr,int dc,int size);void OutputBoard(int size);const n=8;int tile=1;int Boardnn;void main()TileBoard( 0, 0, 3, 2, n );OutputBoard( n );void TileBoard(int tr,int tc,int dr,int dc,int size)/覆盖残缺棋盘if(size=1) return;int t=tile+,/所使用的三格板的数目s=size/2;/象限大小/覆盖左上象限if(drtr+s&dctc+s)/残缺方格位于本象限TileBoard(tr,tc,dr,dc,s);else/本象限中没有残缺方格, 把三格板t放在右下角Boardtr+s-1tc+s-1=t;/覆盖其余部分TileBoard(tr,tc,tr+s-1,tc+s-1,s);/覆盖右上象限if(dr=tc+s)/残缺方格位于本象限TileBoard(tr,tc+s,dr,dc,s);else/本象限中没有残缺方格, 把三格板t放在左下角Boardtr+s-1tc+s=t;/覆盖其余部分TileBoard(tr,tc+s,tr+s-1,tc+s,s);/覆盖左下象限if(dr=tr+s&dc=tr+s&dc=tc+s)/残缺方格位于本象限TileBoard(tr+s,tc+s,dr,dc,s);else/把三格板t放在左上角Boardtr+stc+s=t;/覆盖其余部分TileBoard(tr+s,tc+s,tr+s,tc+s,s
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 9-Fluorenol-d9-9-Hydroxyfluorene-d-sub-9-sub-生命科学试剂-MCE
- 从江山医院面试题及答案看医疗行业的专业素养
- 绿色建筑与居住环境评估面试题
- 2025年职业保安考试题库及答案
- 2025探伤人员培训试题及答案
- 企业招聘面试题库:县级企业的面试经验分享
- 技术员考试题库及答案
- 从一线招聘看职业发展方向:基层岗位面试题及答案学习心得
- 氢能源行业高级人才选拔面试题库
- 电器外贸行业的新发展趋势与面试题目
- 花卉学 二年生花卉
- 附件1:中国联通动环监控系统B接口技术规范(V3.0)
- 箱变设备台账
- GB/T 1185-2006光学零件表面疵病
- 微课(比喻句)讲课教案课件
- 银行间本币市场业务简介
- 2023年厦门东海职业技术学院辅导员招聘考试笔试题库及答案解析
- 辽阳市出租汽车驾驶员从业资格区域科目考试题库(含答案)
- (完整版)剑桥通用五级PET考试练习题
- DB32- 4385-2022《锅炉大气污染物排放标准》
- 钢丝绳课件-图文
评论
0/150
提交评论