全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
棋盘覆盖问题问题描述: 在一个2k2k(k0)个方格组成的棋盘中,恰有一个方格与其他方格不同,称该方格为特殊方格。显然,特殊方格在棋盘中出现的位置有4k中情形,因而有4k中不同的棋盘,图(a)所示是k=2时16种棋盘中的一个。棋盘覆盖问题要求用图(b)所示的4中不同形状的L型骨牌覆盖给定棋盘上除特殊方格以外的所有方格,且热河亮哥L型骨牌不得重复覆盖。 图(b)图 (a)问题分析:K0时,可将2k2k的棋盘划分为4个2k-12k-1的子棋盘。这样划分后,由于原棋盘只有一个特殊方格,所以,这4个子棋盘中只有1个子棋盘中有特殊方格,其余3个子棋盘中没有特殊方格。为了将这3个没有特殊方格的子棋盘转化成为特殊棋盘,以便采用递归方法求解,可以用一个L型骨牌覆盖这3个较小的棋盘的会合处,从而将原问题转化为4个较小规模的棋盘覆盖问题。递归地使用这种划分策略,直至将棋盘分割为11的子棋盘。问题求解:下面介绍棋盘覆盖问题中数据结构的设计。(1) 棋盘:可以用一个二维数组boardsizesize表示一个棋盘,其中size=2k。为了在递归处理的过程中使用同一个棋盘,将数组board设为全局变量。(2) 子棋盘:整个棋盘用二维数组boardsizesize表示,其中的子棋盘由棋盘左上角的下标tr、tc和棋盘大小s表示。(3) 特殊方格:用boarddrdc表示特殊方格,dr和dc是该特殊方格在二维数组board中的下标。(4) L型骨牌:一个2k2k的棋盘中有一个特殊方格,所以,用到L型骨牌的个数为(4k-1)/3,将所有L型骨牌从1开始连续编号,用一个全局变量tile表示。C语言源码:/*author: 彭洪伟 *studentID:0950310006 *class:计科1班 *problem:分治法解决棋盘覆盖问题 */#include #include int tile=1; /记录骨牌的型号int board2020=0; /存储棋盘被覆盖的情况void 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 (drtr+s&dctc+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=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=tr+s&dc=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; ipow(2,k);
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026年度中国建设银行辽宁省分行校园招聘备考题库含答案详解(轻巧夺冠)
- 2025邢台银行股份有限公司邯郸曲周支行招聘14人备考题库(含答案详解)
- 2025巴彦淖尔市磴口县第三批社区工作者招聘60人备考题库含答案详解(综合卷)
- 2025年安阳市公安机关招聘留置看护辅警46人备考题库完整参考答案详解
- 健康信念模式提升糖尿病筛查依从性策略
- 四川省自然资源资产储备中心2025年公开考核招聘专业技术人员笔试考试参考题库及答案解析
- 中国建设银行上海市分行2026年度校园招聘备考题库(450人)及答案详解(典优)
- 2026东莞银行秋季校园招聘备考题库含答案详解(轻巧夺冠)
- 2026“梦想靠岸”招商银行东莞分行冬季校园招聘备考题库附答案详解(突破训练)
- 2025年甘肃省武威市民勤县收成镇人民政府选聘专业化管理村文书备考题库附答案详解(夺分金卷)
- GB/T 18711-2025选煤用磁铁矿粉试验方法
- 上消化道出血疾病宣教
- T-CECRPA 015-2025 跨黄河中上游公路斜拉桥绿色低碳建造评价标准
- 学堂在线 大数据机器学习 章节测试答案
- 红十字理论试题及答案
- 快递客户维护与开发课件
- 少年读史记帝王之路课件
- 2025年小学英语毕业考试模拟卷(英语综合实践)英语歌曲填词训练
- 2025年全国出租车从业资格考试模拟复习题库及答案(共500题)
- 知道智慧树中国茶文化与茶健康课后章节测试满分答案满分测试答案
- 数字农业课件
评论
0/150
提交评论