- 1、本文档共39页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
算法分析若干实例问题解析
最小长度电路板排列问题
问题描述小长度电路板排列问题是大规模电子系统设计中提出的实际问题。该问题的提法是:将n块电路板以最佳排列方案插入带有n个插槽的机箱中。n块电路板的不同的排列方式对应于不同的电路板插入方案。设B={1,2,…,n}是n块电路板的集合。集合L={N1?,N2?,…,Nm?}是n块电路板的m个连接块。其中每个连接块Ni?是B的一个子集,且Ni?中的电路板用同一根导线连接在一起。
连接块的长度是指该连接块中第1块电路板到最后1块电路板之间的距离。试设计一个分支限界法找出所给n个电路板的最佳排列,使得m个连接块中最大长度达到最小。
例:如图,设n=8,m=5,给定n块电路板及其m个连接块:B={1,2,3,4,5,6,7,8},N1={4,5,6},N2={2,3},N3={1,3},N4={3,6},N5={7,8};这8块电路板两个可能的排列如图所示:
?在最小长度电路板排列问题中,连接块的长度是指该连接块中第1块电路板到最后1块电路板之间的距离。例如在左图示的电路板排列中,连接块N4的第1块电路板在插槽3中,它的最后1块电路板在插槽6中,因此N4?的长度为3。同理N2?的长度为2。图中连接块最大长度为3。试设计一个分支限界法找出所给n个电路板的最佳排列,使得m个连接块中最大长度达到最小。
输入数据:第一行有2个正整数n和m。接下来的n行中,每行有m个数。第k行的第j个数为0表示电路板k不在连接块j中,1表示电路板k在连接块j中。输出数据为计算出的电路板排列最小长度与相应的排列方式。
SampleInput
85
11111
01010
01110
10110
10100
11010
00001
01001
SampleOutput
4
算法分析若干实例问题解析全文共1页,当前为第1页。54316287
算法分析若干实例问题解析全文共1页,当前为第1页。
可用策略?电路板排列问题是NP难问题,因此不大可能找到解此问题的多项式时间算法。首先考虑分治的方法,因为不同连接块连接了不同的电路板,原问题很难分解成互不相关的子问题,所以不考虑分治法。其次考虑贪婪法,逐步满足每个连接块的局部最优解,很容易想出并不能得到全局最优解。使用动态规划方法也没有办法解答这个问题。可用算法有回溯法和分支限界法。采用回溯法予以解答。
算法设计考虑采用回溯法系统的搜索问题解空间的排列树,找出电路板的最佳排列。设用数组B表示输入。B[i][j]的值为1当且仅当电路板i在连接块Nj中。设low[i]表示第i块连接块中最左边的电路板的下标,high[i]表示第i快连接块中最右边的电路板的下标。
回溯法搜索排列树的算法一般可以描述如下:
voidbacktrack(intt){
if(tn)?
?output(x);
else
?for(inti=t;in;i++){
??swap(x[t],x[i]);
??if(constraint(t)bound(t))
???backtrack(t+1);
??swap(x[t],x[i]);
?}
}
在这个问题中,output(x),即所有已经排列好,更新最优排列。当in时,电路板排列尚未完成。X[1:i]的是当前扩展结点所相应的部分排列,high[i]-low[i]表示相应的部分最大长度,在当前部分排列之后加入一块未排定的电路板,扩展当前部分排列产生当前扩展结点的一个儿子结点。对于这个儿子结点,计算新的最大长度。仅当lenbestd时候,算法搜索相应的子树,否则该子树被剪去。
按上述回溯搜索策略设计的算法如下:
实例/执行结果
using?namespace?std;??
class?minBoard{??
public:??
????minBoard(int?n,?int?m,?int?*B);??
????int*?getBestx(){return?bestx;}??
????int?getMinl(){return?minl;}??
private:??????
????int?minl;//最优最大长度??
????int?nowl;//当前最大长度??
????int?*low;//low[i]表示第i块连接块中最左边的电路板的下标??
????int?*high;//high[i]表示第i快连接块中最右边的电路板的下标??
????int?*x;//当前解向量??
???
您可能关注的文档
- 第02章.矿床学基本概念-中国地质大学(北京)矿床学.pptx
- 第07讲轴向力应变.pptx
- 第18课《中国石拱桥》课件(共31页)2022-2023学年部编版语文八年级上册.pptx
- 第1章-身份与自我.pptx
- 第1课-计算机网络(课件)浙教版(2023)初中信息技术七年级上册.pptx
- 第3章-液态电解质与固态电解质.pptx
- 第3章-牵引变电所容量计算与确定.pptx
- 第5章-WCDMA物理层的功能.doc
- 第5章边坡工程监测.pptx
- 第6章-分支界限法.pptx
- 硬笔书法基础笔画第三课撇课件-小学生书法.pptx
- 2.2.2一元二次不等式课件-高三中职数学一轮复习.pptx
- 18我喜欢我自己课件-一年级上册心理健康北师大版.pptx
- 第四课《接纳自己的情绪》(给自己的一封信)课件苏教版初中心理健康八年级全一册.pptx
- 第十二课《激发学习动机》课件苏教版心理健康七年级全一册.pptx
- 2.2.3绝对值不等式课件-高三中职数学一轮复习.pptx
- 中学生班主任培训课件.pptx
- 第十六课《你的心情我最懂》(情绪侦探)课件苏教版初中心理健康八年级全一册.pptx
- 专题一集合与简易逻辑课件-广西中职对口升学数学一轮复习.pptx
- 2.3均值定理课件-高三中职数学一轮复习.pptx
最近下载
- 中医整脊疗法选择题及答案.pdf
- 低脂高蛋白的健康风潮——即食鸡胸肉品类报告.pdf
- 统编版2024新版七年级上册道德与法治知识点提纲(实用,必备!).docx
- ANSI CTA-2034-A-2015 家用扬声器的标准测量方法 Standard Method of Measurement for In-Home Loudspeakers.pdf
- 撤销清算组备案及债权人公告范文.docx
- NYT2915-2016 水稻高温热害鉴定与分级.pdf
- 道德与法治优质课教研评比活动总结简报2021《课堂展风采 教研促成长 》.docx
- 端正入党动机以实际行动争取入党课件.pptx VIP
- 15 特殊健康状态儿童预防接种专家共识之十五——自身免疫性疾病与预防接种_孙金峤.pdf VIP
- 医院培训课件:《用药错误案例分析之RCA根本原因分析法》.pptx
文档评论(0)