0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

分支限界法与回溯法算法的详细资料概述

算法与数据结构 来源:未知 作者:易水寒 2018-06-12 19:40 次阅读

分支限界法与回溯法

(1)求解目标:回溯法的求解目标是找出解空间树中满足约束条件的所有解,而分支限界法的求解目标则是找出满足约束条件的一个解,或是在满足约束条件的解中找出在某种意义下的最优解。 (2)搜索方式的不同:回溯法以深度优先的方式搜索解空间树,而分支限界法则以广度优先或以最小耗费优先的方式搜索解空间树。

分支限界法的基本思想

分支限界法常以广度优先或以最小耗费(最大效益)优先的方式搜索问题的解空间树。在分支限界法中,每一个活结点只有一次机会成为扩展结点。活结点一旦成为扩展结点,就一次性产生其所有儿子结点。在这些儿子结点中,导致不可行解或导致非最优解的儿子结点被舍弃,其余儿子结点被加入活结点表中。 此后,从活结点表中取下一结点成为当前扩展结点,并重复上述结点扩展过程。这个过程一直持续到找到所需的解或活结点表为空时为止。

常见的两种分支限界法

(1)队列式(FIFO)分支限界法 按照队列先进先出(FIFO)原则选取下一个结点为扩展结点。 (2)优先队列式分支限界法 按照优先队列中规定的优先级选取优先级最高的结点成为当前扩展结点。

一、单源最短路径问题

1、问题描述

在下图所给的有向图G中,每一边都有一个非负边权。要求图G的从源顶点s到目标顶点t之间的最短路径。

分支限界法与回溯法算法的详细资料概述

下图是用优先队列式分支限界法解有向图G的单源最短路径问题产生的解空间树。其中,每一个结点旁边的数字表示该结点所对应的当前路长。

分支限界法与回溯法算法的详细资料概述

找到一条路径:

分支限界法与回溯法算法的详细资料概述

目前的最短路径是8,一旦发现某个结点的下界不小于这个最短路进,则剪枝:

分支限界法与回溯法算法的详细资料概述

同一个结点选择最短的到达路径:

分支限界法与回溯法算法的详细资料概述

分支限界法与回溯法算法的详细资料概述

2.剪枝策略

算法扩展结点的过程中,一旦发现一个结点的下界不小于当前找到的最短路长,则算法剪去以该结点为根的子树。

在算法中,利用结点间的控制关系进行剪枝。从源顶点s出发,2条不同路径到达图G的同一顶点。由于两条路径的路长不同,因此可以将路长长的路径所对应的树中的结点为根的子树剪去。

3.算法思想

解单源最短路径问题的优先队列式分支限界法用一极小堆来存储活结点表。其优先级是结点所对应的当前路长。

算法从图G的源顶点s和空优先队列开始。结点s被扩展后,它的儿子结点被依次插入堆中。此后,算法从堆中取出具有最小当前路长的结点作为当前扩展结点,并依次检查与当前扩展结点相邻的所有顶点。如果从当前扩展结点i到顶点j有边可达,且从源出发,途经顶点i再到顶点j的所相应的路径的长度小于当前最优路径长度,则将该顶点作为活结点插入到活结点优先队列中。这个结点的扩展过程一直继续到活结点优先队列为空时为止。

实现

* 作者:chinazhangjie

* 邮箱:chinajiezhang@gmail.com

* 开发语言:C++

* 开发环境:Mircosoft Virsual Studio 2008

* 时间: 2010.11.01

*/

#include

#include

#include

#include

using namespacestd;

structnode_info

{

public:

node_info(inti,intw)

: index(i),weight(w){}

node_info()

: index(0),weight(0){}

node_info(constnode_info & ni)

: index(ni.index),weight(ni.weight){}

friend

booloperator < (constnode_info& lth,constnode_info& rth){

returnlth.weight > rth.weight;// 为了实现从小到大的顺序

}

public:

intindex;// 结点位置

intweight;// 权值

};

structpath_info

{

public:

path_info()

: front_index(0),weight(numeric_limits::max()){}

public:

intfront_index;

intweight;

};

// single source shortest paths

classss_shortest_paths

{

public:

ss_shortest_paths(constvector >& g,intend_location)

:no_edge(-1),end_node(end_location),node_count(g.size()),graph(g)

{}

// 打印最短路径

voidprint_spaths()const{

cout << "min weight : " << shortest_path << endl;

cout << "path: ";

copy(s_path_index.rbegin(),s_path_index.rend(),

ostream_iterator (cout," "));

cout << endl;

}

// 求最短路径

voidshortest_paths(){

vector path(node_count);

priority_queue > min_heap;

min_heap.push(node_info(0,0));// 将起始结点入队

while(true){

node_info top = min_heap.top();// 取出最大值

min_heap.pop();

// 已到达目的结点

if(top.index == end_node){

break;

}

// 未到达则遍历

for(inti = 0;i < node_count; ++ i){

// 顶点top.index和i间有边,且此路径长小于原先从原点到i的路径长

if(graph[top.index][i] != no_edge &&

(top.weight + graph[top.index][i]) < path[i].weight){

min_heap.push(node_info(i,top.weight + graph[top.index][i]));

path[i].front_index = top.index;

path[i].weight = top.weight + graph[top.index][i];

}

}

if(min_heap.empty()){

break;

}

}

shortest_path = path[end_node].weight;

intindex = end_node;

s_path_index.push_back(index);

while(true){

index = path[index].front_index;

s_path_index.push_back(index);

if(index == 0){

break;

}

}

}

private:

vector >graph;// 图的数组表示

intnode_count;// 结点个数

constintno_edge;// 无通路

constintend_node;// 目的结点

vectors_path_index;// 最短路径

intshortest_path;// 最短路径

};

intmain()

{

constintsize = 11;

vector > graph(size);

for(inti = 0;i < size; ++ i){

graph[i].resize(size);

}

for(inti = 0;i < size; ++ i){

for(intj = 0;j < size; ++ j){

graph[i][j] = -1;

}

}

graph[0][1] = 2;

graph[0][2] = 3;

graph[0][3] = 4;

graph[1][2] = 3;

graph[1][5] = 2;

graph[1][4] = 7;

graph[2][5] = 9;

graph[2][6] = 2;

graph[3][6] = 2;

graph[4][7] = 3;

graph[4][8] = 3;

graph[5][6] = 1;

graph[5][8] = 3;

graph[6][9] = 1;

graph[6][8] = 5;

graph[7][10] = 3;

graph[8][10] = 2;

graph[9][8] = 2;

graph[9][10] = 2;

ss_shortest_paths ssp(graph,10);

ssp.shortest_paths();

ssp.print_spaths();

return0;

}

测试数据(图)

分支限界法与回溯法算法的详细资料概述

测试结果

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 算法
    +关注

    关注

    23

    文章

    4612

    浏览量

    92924
  • fifo
    +关注

    关注

    3

    文章

    388

    浏览量

    43690
  • 回溯法
    +关注

    关注

    0

    文章

    2

    浏览量

    6127

原文标题:分支限界法

文章出处:【微信号:TheAlgorithm,微信公众号:算法与数据结构】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    求allegro高速信号蛇形走线和10度线的走详细资料

    求高速信号蛇形走线和10度线的走详细资料,先谢谢啦!!!
    发表于 07-06 02:26

    调制解调器和积分器算法程序的详细资料概述

    本文的主要内容介绍的是调制解调器和积分器算法程序的详细资料概述
    发表于 04-28 10:20 11次下载
    调制解调器和积分器<b class='flag-5'>算法</b>程序的<b class='flag-5'>详细资料</b><b class='flag-5'>概述</b>

    五大常用算法回溯

    回溯算法实际上一个类似枚举的搜索尝试过程,主要是在搜索尝试过程中寻找问题的解,当发现已不满足求解条件时,就“回溯”返回,尝试别的路径。
    的头像 发表于 05-02 16:50 5967次阅读
    五大常用<b class='flag-5'>算法</b>之<b class='flag-5'>回溯</b><b class='flag-5'>法</b>

    TI的基于DSP兼容的第三方算法协议的详细资料概述

    本文的主要内容介绍的是TI的基于DSP兼容的第三方算法协议的详细资料概述
    发表于 05-07 17:04 8次下载
    TI的基于DSP兼容的第三方<b class='flag-5'>算法</b>协议的<b class='flag-5'>详细资料</b><b class='flag-5'>概述</b>

    PID程序算法详细资料概述免费下载

    本文档的主要内容详细介绍的是PID程序算法详细资料概述免费下载
    发表于 07-24 08:00 36次下载

    SV601187的详细资料合集包括了电路图,原理图和介绍等详细资料概述

    本文档的主要内容详细介绍的是SV601187的详细资料合集包括了电路图,原理图和介绍等详细资料概述
    发表于 07-30 08:00 18次下载
    SV601187的<b class='flag-5'>详细资料</b>合集包括了电路图,原理图和介绍等<b class='flag-5'>详细资料</b><b class='flag-5'>概述</b>

    十一个经典的滤波算法的介绍和示例程序详细资料免费下载

    本文档的主要内容详细介绍的是十一个经典的滤波算法详细资料免费下载主要内容包括了:1、限幅滤波(又称程序判断滤波)2、中位值滤波
    发表于 11-06 19:35 20次下载
    十一个经典的滤波<b class='flag-5'>算法</b>的介绍和示例程序<b class='flag-5'>详细资料</b>免费下载

    线性系统的频域分析频率特性详细资料免费下载

    本文档的主要内容详细介绍的是线性系统的频域分析频率特性详细资料免费下载。
    发表于 11-22 08:00 5次下载
    线性系统的频域分析频率特性<b class='flag-5'>法</b>的<b class='flag-5'>详细资料</b>免费下载

    5500极谱DO探头校准及维护的资料说明

    本文档的主要内容详细介绍的是HACH SC200+5500 极谱DO探头校准及维护的详细资料免费下载。
    发表于 01-03 08:00 0次下载
    5500极谱<b class='flag-5'>法</b>DO探头校准及维护的<b class='flag-5'>资料</b>说明

    单片机有哪些常用滤波算法详细资料说明

    本文档的主要内容详细介绍的是单片机有哪些常用滤波算法详细资料说明包括了:1、限幅滤波,2、中位值滤波,3、算术平均滤波
    发表于 07-29 17:36 4次下载
    单片机有哪些常用滤波<b class='flag-5'>算法</b><b class='flag-5'>详细资料</b>说明

    分形插值算法详细资料说明

    本文档的主要内容详细介绍的是分形插值算法详细资料说明包括了:1.插值,2.随机中点位移生成山,3.分形插值算法生成云和山。
    发表于 06-05 08:00 0次下载
    分形插值<b class='flag-5'>算法</b>的<b class='flag-5'>详细资料</b>说明

    龙格-库塔的MATLAB代码及含义的详细资料说明

    本文档的主要内容详细介绍的是龙格-库塔的MATLAB代码及含义的详细资料说明。
    发表于 07-17 17:02 6次下载

    python的内置函数详细资料概述

    本文档的主要内容详细介绍的是python的内置函数详细资料概述
    发表于 11-18 08:00 0次下载

    EMC HF垫圈的详细资料概述

    本文档的主要内容详细介绍的是EMC HF垫圈的详细资料概述免费下载。
    发表于 09-07 08:00 0次下载
    EMC HF垫圈的<b class='flag-5'>详细资料</b><b class='flag-5'>概述</b>

    如何使用回溯实现网络设计问题算法的设计

    中网络设计问题对石油传输网络最少增压器的问题有了详细的描述,再次,我们选用回溯来解决这个问题,并对时间复杂度进行了分析和讨论。
    发表于 12-11 08:00 7次下载
    如何使用<b class='flag-5'>回溯</b><b class='flag-5'>法</b>实现网络设计问题<b class='flag-5'>算法</b>的设计