分支限界法
分支限界法解题算法框架

分支限界法解题算法框架分支限界法是一种建模和求解复杂优化问题的有效算法,它源于笛卡尔的科学思想,被认为是能够解决复杂优化问题的革命性工具。
它的基本思想是:分支限界法以树状结构的方式求解优化问题,不断的分割搜索空间,找到最优解。
1、分支限界法的基本概念分支限界法是求解优化问题的一种方法,它将解空间划分为若干个子空间,在每个子空间中评估优化指标,根据分支限界准则,搜索最优解。
它主要分为以下几个步骤:(1)定义一个有限的决策空间,并设置目标函数的优化指标;(2)将决策空间划分为若干个子空间,并设置有效限界和分裂标准;(3)在每个子空间中进行搜索,并进行评价;(4)根据评价结果,重复(2)、(3)步骤,直至满足停止条件,搜索得到最优解。
2、分支限界法的优势分支限界法是一种求解优化问题的有效算法,它在优化技术中占有很重要的地位。
其优势在于:(1)分支限界法可以使用更少的计算量,求解复杂的优化问题;(2)分支限界法采用分支和分割的方式,可以更好的避免搜索局部最优,获得更可靠的最优解;(3)分支限界法可以认为是一种智能化、自适应的搜索技术,它可以有效提高计算效率;(4)分支限界法易于理解,实现比较容易,可以节省程序员的工作量和计算时间。
3、案例应用分支限界法在很多领域有广泛的应用,其中最常见的应用是解决资源分配问题。
可以将需要分配的资源划分为若干个变量,然后使用分支限界法寻找该资源分配问题的最优解。
在运输问题中,如果要在有限的时间内最大限度地利用车辆从一个汽车站点出发,向其他若干个目的地发送货物,可以使用分支限界法来求解,以便在有限的时间内找到最优解。
在装配线调度问题中,如果要解决多个工序同时进行的装配线调度问题,则可以使用分支限界法来求解。
4、总结分支限界法解题算法是一种求解优化问题的有效算法,它将求解空间划分为若干个子空间,采用分支和分割的方式,找到最优解。
该算法具有计算量小、避免搜索局部最优、易于实现等优点,可以用于解决复杂优化问题,在资源分配、运输、装配线调度等领域都有广泛的应用。
分支限界法

一、分支限界法:分支限界法类似于回溯法,也是一种在问题的解空间树T上搜索问题解的算法。
但在一般情况下,分支限界法与回溯法的求解目标不同。
回溯法的求解目标是找出T 中满足约束条件的所有解,而分支限界法的求解目标则是找出满足约束条件的一个解,或是在满足约束条件的解中找出使用某一目标函数值达到极大或极小的解,即在某种意义下的最优解。
由于求解目标不同,导致分支限界法与回溯法在解空间树T上的搜索方式也不相同。
回溯法以深度优先的方式搜索解空间树T,而分支限界法则以广度优先或以最小耗费优先的方式搜索解空间树T。
分支限界法的搜索策略是:在扩展结点处,先生成其所有的儿子结点(分支),然后再从当前的活结点表中选择下一个扩展对点。
为了有效地选择下一扩展结点,以加速搜索的进程,在每一活结点处,计算一个函数值(限界),并根据这些已计算出的函数值,从当前活结点表中选择一个最有利的结点作为扩展结点,使搜索朝着解空间树上有最优解的分支推进,以便尽快地找出一个最优解。
二、分支限界法的基本思想:分支限界法常以广度优先或以最小耗费(最大效益)优先的方式搜索问题的解空间树。
问题的解空间树是表示问题解空间的一棵有序树,常见的有子集树和排列树。
在搜索问题的解空间树时,分支限界法与回溯法对当前扩展结点所使用的扩展方式不同。
在分支限界法中,每一个活结点只有一次机会成为扩展结点。
活结点一旦成为扩展结点,就一次性产生其所有儿子结点。
在这些儿子结点中,那些导致不可行解或导致非最优解的儿子结点被舍弃,其余儿子结点被子加入活结点表中。
此后,从活结点表中取下一结点成为当前扩展结点,并重复上述结点扩展过程。
这个过程一直持续到找到所求的解或活结点表为空时为止。
三、选择下一扩展结点的不同方式:从活结点表中选择下一扩展结点的不同方式导致不同的分支限界法。
最常见的有以下两种方式:1、队列式(FIFO)分支限界法:队列式分支限界法将活结点表组织成一个队列,并按队列的先进先出原则选取下一个结点为当前扩展结点。
分支限界法——TSP问题讲诉

算法中while循环的终止条件是排列树的一个叶结点成为 当前扩展结点。当s=n-1时,已找到的回路前缀是x[0:n1],它已包含图G的所有n个顶点。因此,当s=n-1时,相 应的扩展结点表示一个叶结点。此时该叶结点所相应的回 路的费用等于cc和lcost的值。剩余的活结点的lcost值不 小于已找到的回路的费用。它们都不可能导致费用更小的 回路。因此已找到叶结点所相应的回路是一个最小费用旅 行售货员回路,算法可结束。 算法结束时返回找到的最小费用,相应的最优解由数组v 给出。
0
当前最优解,故没必要扩展
结点C
结点I本身的费用已高于当前 最优解,故没必要扩展结点I
此时,优先队列为空,算法 终止。
算法的while循环体完成对排列树内部结点的扩展。
对于当前扩展结点,算法分2种情况进行处理:
①首先考虑s=n-2的情形,此时当前扩展结点是排列树中某个叶结点的父结 点。如果该叶结点相应一条可行回路且费用小于当前最小费用,则将该叶结 点插入到优先队列中,否则舍去该叶结点。 ②当s<n-2时,算法依次产生当前扩展结点的所有儿子结点。由于当前扩展 结点所相应的路径是x[0:s],其可行儿子结点是从剩余顶点x[s+1:n-1]中选 取的顶点x[i],且(x[s],x[i])是所给有向图G中的一条边。对于当前扩展结点 的每一个可行儿子结点,计算出其前缀(x[0:s],x[i])的费用cc和相应的下界 lcost。当lcost<bestc时,将这个可行儿子结点插入到活结点优先队列中。
算法: 1.找出中间的蚂蚁离两端的距离中较小的。
a[2]=11
a[2]''=27-11=14, 因为a[2]<a[2]'',所以最小距离是11,时间11/1=11 2.找出两端的蚂蚁距两端的距离中较大的。
回溯法与分支限界法

回溯法与分支限界法
回溯法和分支限界法是两种常见的搜索算法,它们被广泛应用于解决优化问题、约束满足问题以及决策问题等。
1. 回溯法:
回溯法是一种基于试错的搜索算法。
它通过搜索解空间树来寻找问题的解。
在搜索过程中,回溯法会尝试不同的分支,也就是不同的可能解,直到找到解或者确定无解。
如果一条路径上无法得到解,回溯法就会回溯到上一步,尝试其他的分支。
回溯法的优点是它可以找到问题的所有解,而且对于一些问题,它能够找到最优解。
然而,它的缺点是如果问题的解空间树太大,那么回溯法可能会需要大量的时间和空间。
2. 分支限界法:
分支限界法是一种有约束的深度优先搜索算法。
它也是一种用于求解优化问题的算法。
在分支限界法中,搜索过程被分为两个阶段:扩展阶段和限界阶段。
在扩展阶段,算法会生成所有可能的候选解,并将它们加入到候选解集中。
在限界阶段,算法会根据一些启发式信息对候选解进行排序,并只考虑排在最前面的候选解。
这样可以大大减少搜索的时间和空间复杂度。
分支限界法的优点是它可以找到问题的最优解,而且它的时间复杂度是可以控制的。
然而,它的缺点是如果问题的解空间树太大,那么它可能需要大量的内存来存储候选解。
总的来说,回溯法和分支限界法都是非常重要的搜索算法,它们在不同的场景下都有各自的优势和适用性。
简述回溯法和分支限界法的异同

回溯法和分支限界法是解决问题时常用的两种算法。
它们都是一种搜索算法,用于在问题空间中寻找问题的解。
虽然它们有着相似的目的,但它们在实现过程和特点上有着不同之处。
下面将对回溯法和分支限界法进行简要的比较,以便更好地理解它们的异同点。
一、回溯法回溯法,又称试探法,是一种通过深度优先搜索的方式来解决问题的算法。
其基本思想是从问题的解空间树根节点出发,按深度优先的方式搜索整个解空间树。
在搜索过程中,当发现到达某个节点时,如果这个节点不满足约束条件,那么就进行回溯,返回到上一层节点继续搜索。
回溯法在寻找解的过程中,常常使用递归进行实现。
回溯法的特点:1. 深度优先搜索:回溯法使用深度优先搜索的方式遍历解空间树,这意味着它会尽可能深地探索每一个节点,直到找到问题的解或者发现无解。
2. 适用范围广:回溯法可以解决非常多种类的问题,比如八皇后问题、0-1背包问题等等。
只要问题可以建模成解空间树的形式,就可以使用回溯法进行解决。
3. 隐式的剪枝:在回溯法的搜索过程中,由于采用了深度优先搜索的方式,所以会自带一定的隐式剪枝效果。
即在搜索到某一节点时,如果发现不满足约束条件,就会立即回溯,从而避免继续搜索无效的节点。
二、分支限界法分支限界法也是一种搜索算法,它与回溯法有相似之处,但在实现细节上有所不同。
分支限界法通过不断将解空间树中的节点分支并进行评估,然后根据当前状态的下界限定来减少搜索范围,从而达到快速寻找最优解的目的。
分支限界法的特点:1. 显式的剪枝:与回溯法不同,分支限界法会显式地在搜索过程中对节点进行剪枝。
这是因为分支限界法在每次分支后都会对节点进行评估,并根据评估结果进行剪枝操作,从而避免不必要的搜索。
2. 寻找最优解:相比于回溯法,分支限界法更适合寻找最优解。
由于它能够通过不断地削减搜索空间来加速搜索过程,因此更适合解决那些需要找到最优解的问题。
3. 需要维护优先队列:在分支限界法的实现过程中,通常需要维护一个优先队列,用于存储待扩展的节点,并根据评估函数的结果进行排序。
第6章 分支限界法

16
算法从图G的源顶点s和空优先队列开始。 算法从图G的源顶点s和空优先队列开始。 结点s被扩展后,它的儿子结点被依次插入堆中。 结点s被扩展后,它的儿子结点被依次插入堆中。 此后, 此后,算法从堆中取出具有最小当前路长的结点 作为当前扩展结点, 作为当前扩展结点,并依次检查与当前扩展结点 相邻的所有顶点。 相邻的所有顶点。 如果从当前扩展结点i到顶点j有边可达, 如果从当前扩展结点i到顶点j有边可达,且从源 出发,途经顶点i再到顶点j 出发,途经顶点i再到顶点j的所相应的路径的长 度小于当前最优路径长度, 度小于当前最优路径长度,则将该顶点作为活结 点插入到活结点优先队列中。 点插入到活结点优先队列中。 这个结点的扩展过程一直继续到活结点优先队列 为空时为止。 为空时为止。
r=14, p=45 不可解 r=14, r=15, p=45 p=25 r=30, p=0
不可解
r=14, p=45
r=0, p=50
7
用队列式分支限界法解此问题时,用一个队列 用队列式分支限界法解此问题时,用一个队列 来存储活结点表。 来存储活结点表。
不可解
队头 B C E F
不可解 G K L M N O
第6章 分支界限法
学习要点
• 理解分支限界法的剪枝搜索策略。 理解分支限界法的剪枝搜索策略。 • 掌握分支限界法的算法框架 (1)队列式(FIFO)分支限界法 队列式(FIFO)分支限界法 (2)优先队列式分支限界法 • 通过应用范例学习分支限界法的设计策略。 通过应用范例学习分支限界法的设计策略。
11
分支限界法

解此问题的队列式分支限界法从起始位置a开头将它作为 第一个扩展结点。与该扩展结点相邻并且可达的方格成为可 行结点被参加到活结点队列中,并且将这些方格标记为1, 即从起始方格a到这些方格的距离为1。
接着,算法从活结点队列中取出队首结点作为下一个扩展 结点,并将与当前扩展结点相邻且未标记过的方格标记为2, 并存入活结点队列。这个过程始终连续到算法搜寻到目标方 格b或活结点队列为空时为止。即参加剪枝的广度优先搜寻。
bestx[j] = bestE->LChild; bestE = bestE->parent; }
16
6.3 装载问题
5. 优先队列式分支限界法
解装载问题的优先队列式分支限界法用最大优先队列存储活 结点表。活结点x在优先队列中的优先级定义为从根结点到结点 x的路径所相应的载重量再加上剩余集装箱的重量之和。
return b;
//b为上界函数
22
6.5 0-1背包问题
while (i != n+1) {// 非叶结点 // 检查当前扩展结点的左儿子结点 Typew wt = cw + w[i]; if (wt <= c) {// 左儿子结点为可行结点 if (cp+p[i] > bestp) bestp = cp+p[i]; AddLiveNode(up, cp+p[i], cw+w[i], true, i+1);} up = Bound(i+1); // 检查当前扩展结点的右儿子结点 if (up >= bestp) // 右子树可能含最优解 AddLiveNode(up, cp, cw, false, i+1); // 取下一个扩展节点〔略〕
第七章 分支限界法

旅行售货员问题
2. 问题分析
可能解空间: 可能解集合S={1,∏, 1} ∏是{2,3,……,n}的一个排列;
所以可能解的总数 |S| = (n-1)! (n-1)!。 当n=4时,其状态解空间一共有3!=6 条路径。
对此设计代价函数: 1)C(x)=从根到节点x的距离(x为叶子) 2)C(x)=x的子树中最小代价的叶子节点的代价(x为 内部节点)
生成问题状态的基本方法
扩展结点: 扩展结点:一个正在产生儿子的结点称为扩展结点 活结点: 活结点:一个自身已生成但其儿子还没有全部生成的节点称 做活结点 死结点: 死结点:一个所有儿子已经产生的结点称做死结点 深度优先的问题状态生成法:如果对一个扩展结点R,一旦 深度优先的问题状态生成法:如果对一个扩展结点R 产生了它的一个儿子C 就把C当做新的扩展结点。 产生了它的一个儿子C,就把C当做新的扩展结点。在完成 对子树C 为根的子树)的穷尽搜索之后, 对子树C(以C为根的子树)的穷尽搜索之后,将R重新变成 扩展结点,继续生成R的下一个儿子(如果存在) 扩展结点,继续生成R的下一个儿子(如果存在) 宽度优先的问题状态生成法: 宽度优先的问题状态生成法:在一个扩展结点变成死结点 之前, 之前,它一直是扩展结点 回溯法:每当出现死节点就进行回溯, 回溯法:每当出现死节点就进行回溯,通过继续扩展父节 点产生新的活节点,直至找到最优解。 点产生新的活节点,直至找到最优解。 分支限界法:每个活节点有且只有一次机会变成扩展节点、 分支限界法:每个活节点有且只有一次机会变成扩展节点、 当一个节点变为扩展节点时,则生成所有的子节点( 当一个节点变为扩展节点时,则生成所有的子节点(分 支)。
剪枝操作。根据约束条件、目标函数的界来设计剪枝操 作。 优先队列。设计待检测结点的优先级。 2.分枝限界法的基本思想 树的优先队列优先搜索 + 剪枝
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
2. 一般情况下,对于一个正在生成的路径,假设已经确定 了前i段(1≤i≤k),其路径为(r1, r2, …, ri, ri+1),此时,该 部分解的目标函数值的计算方法即限界函数如下:
lb
c[r ][r
j j 1
i
+ j 1 ]
ri 1 , v p E
min
{c[ri 1 ][v p ]}
lb v
k i 1
第k行的最小值
n
假设已经将任务2分配给人员a,任务3分配给人员b,花费的 成本是5,则该部分解可能获得的最小成本是5+(1+4)=10。
搜索过程?
任务1 任务2 任务3 任务4
C=
9 6 5 7
2 4 8 6
7 3 1 9
8 7 8 4
a b c d
9.3.3 批处理作业调度问题
9.2 图问题中的分支限界法
9.2.1 TSP问题 9.2.2 多段图的最短路径问题
9.2.1 TSP问题
问题描述:TSP问题是指旅行家要旅行n个城市,要 求各个城市经历且仅经历一次然后回到出发城市, 并要求所走的路程最短。 想法: 确定目标函数的界[down, up] 。(提示:如何确 定上、下界?) 确定目标函数值的计算方法(限界函数)。
分支限界法需要解决的关键问题
如何确定合适的限界函数。(提示:计算简单, 减少搜索空间,不丢解) 如何组织待处理结点表。(提示:表PT可以采用 堆的形式,也可以采用优先队列的形式存储。各有什 么特点?) 如何确定最优解的各个分量。(提示:跳跃式处 理解空树结点,必须保存搜索过程中经过的路径信 息。)
9.1.1 分支限界法的设计思想
确定一个合理的限界函数,并根据限界函数确定目 标函数的界[down, up]。
按照广度优先策略搜索问题的解空间树,在分支结 点上,依次扩展该结点的所有孩子结点,分别估算这 些孩子结点的目标函数的可能取值,某孩子结点的目 标函数的可能取值超出目标函数的界,则将其丢弃; 否则,将其加入待处理结点表(以下简称表PT)中。 依次从表PT中选取使目标函数取得极值的结点成为 当前扩展结点,重复上述过程,直至找到最优解。
9.3.1 9.3.2 9.3.3
9.3.1
0/1 背包问题
问题描述:给定n种物品和一个容量为W的 背包,物品i的重量是wi,其价值为vi,对每种 物品i只有两种选择:装入背包或不装入背 包,如何选择装入背包的物品,使得装入 背包中物品的总价值最大?
想法:
1 确定目标函数上、下界; 2 确定目标函数计算方法;
9.1.3 一个简单的例子—圆排列问题
问题描述:给定n个圆的半径序列,将这些圆放 到一个矩形框中,各圆与矩形框的底边相切,则 圆的不同排列会得到不同的排列长度,要求找出 具有最小长度的圆排列。 想法:采用分支限界法求解圆排列问题,首先 设计限界函数,然后在搜索过程中选择使目标 函数取得极值的结点优先进行扩充。
例如:对于n=3的0/1背包问题解空间树
1 1
0
9
对物品1的选择 0 3 0 12 1 14 0 15 对物品3的选择
2
1 0 6 1 10 0 8 1
对物品2的选择
3
1 4
0
5
1 7
11
图8.2 0/1背包问题的解空间树
分支限界法和回溯法实际上都属于蛮力穷举法,当 然不能指望它有很好的最坏时间复杂性,遍历具有指 数阶个结点的解空间树,在最坏情况下,时间复杂性 肯定为指数阶。
与回溯法不同的是,分支限界法首先扩展解空间树 中的上层结点,并采用限界函数,有利于实行大范围 剪枝,同时,根据限界函数不断调整搜索方向,选择 最有可能取得最优解的子树优先进行搜索。所以,如 果选择了结点的合理扩展顺序以及设计了一个好的限 界函数,分支界限法可以快速得到问题的解。
分支限界法的较高效率是以付出一定代价为基础的,其 工作方式也造成了算法设计的复杂性。首先,一个更好的限 界函数通常需要花费更多的时间计算相应的目标函数值,而 且对于具体的问题实例,通常需要进行大量实验,才能确定 一个好的限界函数;其次,由于分支限界法对解空间树中结 点的处理是跳跃式的,因此,在搜索到某个叶子结点得到最 优值时,为了从该叶子结点求出对应的最优解中的各个分量, 需要对每个扩展结点保存该结点到根结点的路径,或者在搜 索过程中构建搜索经过的树结构,这使得算法的设计较为复 杂;再次,算法要维护一个待处理结点表PT,并且需要在表 PT中快速查找取得极值的结点,等等。这都需要较大的存储 空间,在最坏情况下,分支限界法需要的空间复杂性是指数 阶。
j i 2
第j段的最短边
k
如果部分解包含路径01,则第1段的代价已经确定,并 且在下一段只能从顶点1出发,最好的情况是选择从顶点 1出发的最短边,则该部分解的下界是lb=4+8+5+3=20。
搜 索 空 间
分支限界法求解多段图的最短路径问题,搜索过程?
9.3
组合问题中的分支限界法
0/1 背包问题 任务分配问题 批处理作业调度问题
第九章 分支限界法
1
2 3 4
概述
图问题中的分支限界法
组合问题中的分支限界法 小结
9.1 概述
9.1.1 分枝限界法的设计思想 9.1.2 分枝限界法的时间性能 9.1.3 一个简单例子
---圆排列问题
分支限界法按广度优先策略搜索问题的解空间树,
在搜索过程中,对待处理的结点根据限界函数估算目 标函数的可能取值,从中选取使目标函数取得极值 (极大或极小)的结点优先进行广度优先搜索,从而 不断调整搜索方向,尽快找到问题的解。 分支限界法适用于求解最优化问题。
想法:
批处理作业的一个最优调度应使机器1没有空闲时 间,且机器2和机器3的空闲时间最小。可以证明, 存在一个最优作业调度使得在机器1、机器2和机器 3上作业以相同次序完成。
实例
机器1 机器2 机器3
T=
J1 5 J2 10 J3 9 J4 7
7 5 9 8
9 2 5 10
上界确定的方法:
可以随机产生几个调度方案,从中选取具有最短完 成时间的调度方案作为近似最优解。
问题描述:给定n个作业的集合J={J1, J2, …, Jn}, 每个作业都有3项任务分别在3台机器上完成,作业 Ji需要机器j的处理时间为tij(1≤i≤n, 1≤j≤3),每个 作业必须先由机器 1处理,再由机器2处理,最后由 机器3处理。批处理作业调度问题要求确定这n个作 业的最优处理顺序,使得从第1个作业在机器 1上处 理开始,到最后一个作业在机器 3 上处理结束所需 的时间最少。
机器1
机器2 机器3
J4:7 空闲:7
J1:5 J4:8
J3:9 J1:7 J4:10
J2:10 J3:9 J1:9 J2:5 J3:5 J2:2
i 1 i 1, k r j U k 1
3.基于分支限界法的思想,从根结点开始依次计算 目标函数值加入待处理结点表中直至叶子结点。
[14,16]
∞ 3 1 5 8
3 1 5 ∞ 6 7 6 ∞ 4 7 4 ∞ 9 2 3
k 1 i 1
8 9 2 3 ∞
lb (2 c[ri ][ri 1 ] ri 行不在路径上的最小元素 rj 行最小的两个元素) / 2
回溯法与分支限界法区别?
回溯法从根结点出发,按照深度优先策略遍历问 题的解空间树。
分支限界法按广度优先策略搜索问题的解空间树。
二者与蛮力法区别?
9.1.2 分支限界法的时间性能
类比回溯法分析分支限界法的时间性能 一般情况下,在问题的解向量X=(x1, x2, …, xn) 中 , 分 量 xi (1≤i≤n) 的 取 值 范 围 为 某 个 有 限 集 合 Si={ai1, ai2, …, airi},因此,问题的解空间由笛卡儿 积 A=S1×S2×…×Sn 构成,并且第 1 层的根结点有 |S1| 棵子树,则第 2 层共有 |S1| 个结点,第 2 层的每个 结点有|S2|棵子树,则第3层共有|S1|×|S2|个结点,依 此类推,第 n+1 层共有 |S1|×|S2|×…×|Sn| 个结点, 他们都是叶子结点,代表问题的所有可能解。
搜索过程?
单位价值:10,6,5,4
重量为{4,7,5,3} 价值为{40,42,25,12} 背包容量为10
算法描述:
1. 根据限界函数计算目标函数的上界up; 采用贪心法得到下界down; 2. 计算根结点的目标函数值并加入待处理结点表PT; 3. 循环直到某个叶子结点的目标函数值在表PT中取极大值 3.1 i = 表PT中具有最大值的结点; 3.2 对结点i的每个孩子结点x执行下列操作: 3.2.1 如果结点x不满足约束条件,则丢弃该结点; 3.2.2 否则,估算结点x的目标函数值lb, 将结点x加入表PT中; 4. 将叶子结点对应的最优值输出,回溯求得最优解的各个分量;
求解过程:
1 4 0 2 3 2 4 3 8 8 9 8 6 4 5 6
6 8
6 6
5 7 7 9 3
7
8
5
1. 应用贪心法求得近似解为0→2→5→8→9,其路径代价为 2+7+6+3=18,这可以作为多段图最短路径问题的上界。把每 一段最小的代价相加,可以得到一个非常简单的下界,其路径 长度为2+4+5+3=14。于是,得到了目标函数的界[14, 18]。
基于上、下界,按分支限界法设计思想,搜索解 空间树,得到最优解。
图9.5(a)所示是一个带权无向图,(b)是该图的代价矩阵。
1 3 2 6 7 9
5 8
3 1
C=
4 2
5 3
4
∞ 3 3 ∞ 1 6 5 7 8 9