用分治法求解棋盘覆盖问题_第1页
用分治法求解棋盘覆盖问题_第2页
用分治法求解棋盘覆盖问题_第3页
用分治法求解棋盘覆盖问题_第4页
全文预览已结束

下载本文档

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

文档简介

1、.棋盘覆盖问题问题描述: 在一个2k×2k(k0)个方格组成的棋盘中,恰有一个方格与其他方格不同,称该方格为特殊方格。显然,特殊方格在棋盘中出现的位置有4k中情形,因而有4k中不同的棋盘,图(a)所示是k=2时16种棋盘中的一个。棋盘覆盖问题要求用图(b)所示的4中不同形状的L型骨牌覆盖给定棋盘上除特殊方格以外的所有方格,且热河亮哥L型骨牌不得重复覆盖。 图(b)图 (a)问题分析:K>0时,可将2k×2k的棋盘划分为4个2k-1×2k-1的子棋盘。这样划分后,由于原棋盘只有一个特殊方格,所以,这4个子棋盘中只有1个子棋盘中有特殊方格,其余3个子棋盘中没有特

2、殊方格。为了将这3个没有特殊方格的子棋盘转化成为特殊棋盘,以便采用递归方法求解,可以用一个L型骨牌覆盖这3个较小的棋盘的会合处,从而将原问题转化为4个较小规模的棋盘覆盖问题。递归地使用这种划分策略,直至将棋盘分割为1×1的子棋盘。问题求解:下面介绍棋盘覆盖问题中数据结构的设计。(1) 棋盘:可以用一个二维数组boardsizesize表示一个棋盘,其中size=2k。为了在递归处理的过程中使用同一个棋盘,将数组board设为全局变量。(2) 子棋盘:整个棋盘用二维数组boardsizesize表示,其中的子棋盘由棋盘左上角的下标tr、tc和棋盘大小s表示。(3) 特殊方格:用boar

3、ddrdc表示特殊方格,dr和dc是该特殊方格在二维数组board中的下标。(4) L型骨牌:一个2k×2k的棋盘中有一个特殊方格,所以,用到L型骨牌的个数为(4k-1)/3,将所有L型骨牌从1开始连续编号,用一个全局变量tile表示。C语言源码:/*author: 彭洪伟 *studentID:0950310006 *class:计科1班 *problem:分治法解决棋盘覆盖问题 */#include <stdio.h>#include <math.h>int tile=1; /记录骨牌的型号int board2020=0; /存储棋盘被覆盖的情况void

4、ChessBoard(int tr,int tc,int dr,int dc,int size) /tr和tc是棋盘左上角的下标,dr和dc是特殊方格的下标,size是棋盘的大小int t=0;int s;if (size=1)return;t=tile+;s=size/2; /划分棋盘/覆盖左上角棋盘if (dr<tr+s&&dc<tc+s) /特殊方格在棋盘的左上角ChessBoard(tr,tc,dr,dc,s);elseboardtr+s-1tc+s-1=t;ChessBoard(tr,tc,tr+s-1,tc+s-1,s);/覆盖右上角棋盘if (dr&l

5、t;tr+s&&dc>=tc+s) /特殊方格在棋盘的右上角ChessBoard(tr,tc+s,dr,dc,s);elseboardtr+s-1tc+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);elseboardtr+stc+s-1=t;ChessBoard(tr+s,tc,tr+s,tc+s-1,s);/覆盖右下角棋盘if (dr>=tr+s&&dc

6、>=tc+s) /特殊方格在棋盘的右下角ChessBoard(tr+s,tc+s,dr,dc,s);elseboardtr+stc+s=t;ChessBoard(tr+s,tc+s,tr+s,tc+s,s);int main()int k,x,y;printf("请输入棋盘的规模K:");scanf("%d",&k); printf("请输入特殊方格的下标x,y:");scanf("%d %d",&x,&y);ChessBoard(0,0,x,y,pow(2,k);for(int i=0; i<pow(2,k); i+)for (int

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论