棋盘覆盖问题课件_第1页
棋盘覆盖问题课件_第2页
棋盘覆盖问题课件_第3页
棋盘覆盖问题课件_第4页
棋盘覆盖问题课件_第5页
已阅读5页,还剩14页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

棋盘覆盖问题问题描述(一)在一个

(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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论