《算法分析》——布线问题

本文介绍了如何使用分支限界法解决布线问题,对比了分支限界法与回溯法的区别,强调分支限界法在寻找最优解时采用广度优先搜索。文章详细阐述了布线问题的解空间、算法思路,包括定义Position类、初始化、搜索步骤以及算法实现,并指出分支限界法可以视为回溯法与贪心算法的结合。
摘要由CSDN通过智能技术生成

布线问题(分支限界法)的算法思想

 

分支限界法和回朔法有相似之处,但是回朔法是搜索问题的所有解,采用深度优先搜索;而分支限界法是搜索问题的最优解,采用的是广度优先搜索;  

一、核心思想:

分支限界法中,每一个活节点都只有一次机会成为扩展节点。活节点一旦成为扩展节点,就一次性产生所有的儿子节点。在这些儿子节点中,导致不可行解或者导致非最优解的儿子节点被舍弃,其余儿子节点被加入活节点表中。此后,从活节点表中取下一节点成为当前扩展节点,并重复上述节点的扩展过程。这个过程一直在持续到找到所需要的最优解或者活节点表为空时为止;其中:选择扩展节点的方式可以分为:队列式分支限界法和优先队列式分支限界法。后者相对于前者的改进是对活节点加入了优先级,优先级最高的成为扩展节点(通常通过最大堆最小堆实现);  

 

 二、布线问题描述:

 

三、布线问题分析:

(1)分支限界法的选择

① 解空间是图,如果使用之前所学的回溯法,那么解空间将是一颗子集树

② 回溯法是深度优先,搜索到的可行解不一定是最优解,它会一条路走到黑,然后计算出一条路径,然后回到起点&

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值