




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
棋盘覆盖问题问题描述(一)在一个
(k≥0)个方格组成的棋盘中,恰有一个方格与其他方格不同,称该方格为特殊方格,显然,特殊方格在棋盘中出现的位置有中情形,因而有中不同的棋盘(如图(a))。(a)
k=2时的一种棋盘问题描述(二)
棋盘覆盖问题要求用如图(b)所示的L型骨牌覆盖给定棋盘上除特殊方格以外的所有方格,且任何2个L型骨牌不得重叠覆盖。(b)4种不同形状的L型骨牌问题分析(一)
用分治策略,可以设计解棋盘覆盖问题的一个简洁算法
(1)当k>0时,将棋盘分割为4个子棋盘(如下图(c));2k-1×2k-12k-1×2k-12k-1×2k-12k-1×2k-1特殊方格必位于4个子棋盘之一,其余3个子棋盘中无特殊方格。(c)棋盘分割问题分析(二)
(2)用一个L型骨牌覆盖这3个较小棋盘的结合处。(如图(d))这3个子棋盘上被L型骨牌覆盖的方格就成为该棋盘上的残缺方格,原问题转化为4个较小规模的棋盘覆盖问题。递归地使用这种分割,直至棋盘简化为11棋盘。(d)
构造相同子问题详细过程图解如下棋盘中有一个特殊方格第一次分割第二次分割第三次分割第四次分割为1×1棋盘第一次分割后子棋盘的覆盖结果问题求解下面介绍棋盘覆盖问题中数据结构的设计:(1)棋盘:用二维数组Board[size][size]表示一个棋盘,Board[0][0]是棋盘的左上角方格。其中,size=
。为了在递归处理的过程中使用同一个棋盘,将数组Board设为全局变量;(2)子棋盘:在棋盘数组Board[size][size]中,由子棋盘左上角的下标tr、tc和棋盘边长s表示;(3)特殊方格:用Board[dr][dc]表示,dr和dc是该特殊方格在棋盘数组Board中的下标;(4)L型骨牌:一个的棋盘中有一个特殊方格,所以用到L型骨牌的个数为(
-1)/3将所有L型骨牌从1开始连续编号,用一个全局整型变量tile表示,其初始值为0。算法的输入参数是:tr:棋盘左上角方格的行号tc:棋盘左上角方格的列号dr:特殊方格所在的行号dc:特殊方格所在的列号size:size=,棋盘规格为dcdrtrtcsize棋盘覆盖问题中的数据结构算法—棋盘覆盖
实现这种分治策略的算法ChessBoard如下:voidChessBoard(inttr,inttc,intdr,intdc,intsize)//tr和tc是棋盘左上角的下标,dr和dc是特殊方格的下标,//size是棋盘的大小,t已初始化为0{if(size==1)return;//棋盘只有一个方格且是特殊方格
t++;//L型骨牌号
s=size/2;//划分棋盘
//覆盖左上角子棋盘
if(dr<tr+s&&dc<tc+s)//特殊方格在左上角子棋盘中
ChessBoard(tr,tc,dr,dc,s);//递归处理子棋盘
else{//用t号L型骨牌覆盖右下角,再递归处理子棋盘
board[tr+s-1][tc+s-1]=t;ChessBoard(tr,tc,tr+s-1,tc+s-1,s);}//覆盖右上角子棋盘if(dr<tr+s&&dc>=tc+s)//特殊方格在右上角子棋盘中ChessBoard(tr,tc+s,dr,dc,s);//递归处理子棋盘else{//用t号L型骨牌覆盖左下角,再递归处理子棋盘board[tr+s-1][tc+s]=t;ChessBoard(tr,tc+s,tr+s-1,tc+s,s);}//覆盖左下角子棋盘if(dr>=tr+s&&dc<tc+s)//特殊方格在左下角子棋盘中ChessBoard(tr+s,tc,dr,dc,s);//递归处理子棋盘else{//用t号L型骨牌覆盖右上角,再递归处理子棋盘board[tr+s][tc+s-1]=t;ChessBoard(tr+s,tc,tr+s,tc+s-1,s);}//覆盖右下角子棋盘if(dr>=tr+s&&dc>=tc+s)//特殊方格在右下角子棋盘中ChessBoard(tr+s,tc+s,dr,dc,s);//递归处理子棋盘else{//用t号L型骨牌覆盖左上角,再递归处理子棋盘board[tr+s][tc+s]=t;ChessBoard(tr+s,tc+s,tr+s,tc+s,s);}}时间复杂度分析算法分析:设T(k)为覆盖棋盘的时间
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 骆驼祥子成果展示课课件
- 2025年电弧故障断路器(AFCI)行业研究报告及未来行业发展趋势预测
- 2025年草酸钛钾行业研究报告及未来行业发展趋势预测
- 马丁路德改革课件
- 雷达吸波涂料项目可行性研究报告
- 量子混合计算CPU项目可行性研究报告
- 宽温域环境下半导体器件热应力累积对耐压性能的隐性损耗
- 多轴联动切割机中开关时序同步精度误差的动态补偿算法研究
- 多材料复合结构在冲压成型中的应力分布仿真分析
- 多任务协同复合加工中刀具磨损与热积累效应的耦合建模
- 2025年城市燃气储气罐采购安装与运营维护服务合同范本
- 病房消毒及卫生管理课件
- 2025年国家公务员考录《行测》真题及参考答案
- 2025年城市管理笔试高频考点
- 艾滋病科普宣传课件
- 水泵房巡检流程培训课件
- 吊装专项施工方案
- 基本药物制度补助资金管理办法
- 无人机培训招生宣讲
- 2025年建筑工地安全培训考试题库试题及答案
- 中国系统性红斑狼疮诊疗指南(2025版)解读
评论
0/150
提交评论