21.boost Ford最短路径算法(效率低)

到某个节点最近距离 最短路径当前节点的父节点
完整代码
#include <iostream>
#include <string>
#include <utility>
#include <vector>
#include <deque>
#include <boost/graph/adjacency_list.hpp>
//A*寻路算法
#include <boost\graph\astar_search.hpp>
//dijsktra
#include <boost\graph\dijkstra_shortest_paths.hpp>
//bellman-Ford算法
#include <boost\graph\bellman_ford_shortest_paths.hpp>
using namespace std;
using namespace boost; void main()
{
//定义节点和边的相关对象和属性
enum { u, v, x, y, z, N };
char name[] = { 'u', 'v', 'x', 'y', 'z' };
typedef std::pair < int, int >E;
E edge_array[] = { E(u, y), E(u, x), E(u, v), E(v, u),
E(x, y), E(x, v), E(y, v), E(y, z), E(z, u), E(z, x) };
int weights[] = { -, , , -, , -, , , , };
int num_arcs = sizeof(edge_array) / sizeof(E); //定义所用的图种类和相关类型
typedef adjacency_list < vecS, vecS, directedS,
no_property, property < edge_weight_t, int > > Graph;
//生成图对象
Graph g(edge_array, edge_array + num_arcs, weights, N);
graph_traits < Graph >::edge_iterator ei, ei_end; //distance用于放置依近到远的路径距离
std::vector<int> distance(N, (std::numeric_limits < short >::max)());
//parent用于放置最短路径生成树的各个顶点的父节点
std::vector<std::size_t> parent(N);
for (int i = ; i < N; ++i)
parent[i] = i; //将源点z对应距离设为0
distance[z] = ;
//应用Bellman-Ford算法
bool r = bellman_ford_shortest_paths
(g, int(N), weight_map(get(edge_weight, g)).distance_map(&distance[]).
predecessor_map(&parent[])); if (r)
{
std::cout << "源点z到各点的最短路径\n";
std::cout << "目的点\t" << "最短路径\t" << "最短路径树的父节点:\n";
for (int i = ; i < N; ++i)
std::cout << name[i] << ": \t" << distance[i]
<< "\t\t" << name[parent[i]] << std::endl;
}
else
std::cout << "negative cycle" << std::endl; system("pause");
}
21.boost Ford最短路径算法(效率低)的更多相关文章
- 20.boost dijkstra最短路径算法
		
到某个点的最短距离 到终点的最短路径 完整代码 #include <iostream> #include <string> #include &l ...
 - Dijkstra 单源最短路径算法
		
Dijkstra 算法是一种用于计算带权有向图中单源最短路径(SSSP:Single-Source Shortest Path)的算法,由计算机科学家 Edsger Dijkstra 于 1956 年 ...
 - Bellman-Ford 单源最短路径算法
		
Bellman-Ford 算法是一种用于计算带权有向图中单源最短路径(SSSP:Single-Source Shortest Path)的算法.该算法由 Richard Bellman 和 Leste ...
 - 最短路径算法—Dijkstra(迪杰斯特拉)算法分析与实现(C/C++)
		
Dijkstra算法 ———————————最后更新时间:2011.9.25———————————Dijkstra(迪杰斯特拉)算法是典型的最短路径路由算法,用于计算一个节点到其他所有节点的最短路径. ...
 - 最短路径算法-Dijkstra算法的应用之单词转换(词梯问题)(转)
		
一,问题描述 在英文单词表中,有一些单词非常相似,它们可以通过只变换一个字符而得到另一个单词.比如:hive-->five:wine-->line:line-->nine:nine- ...
 - (转)最短路径算法-Dijkstra算法分析及实践
		
原地址:http://www.wutianqi.com/?p=1890 这篇博客写的非常简洁易懂,其中各个函数的定义也很清晰,配合图表很容易理解这里只选取了 其中一部分(插不来图片). Dijkstr ...
 - Python小白的数学建模课-16.最短路径算法
		
最短路径问题是图论研究中的经典算法问题,用于计算图中一个顶点到另一个顶点的最短路径. 在图论中,最短路径长度与最短路径距离却是不同的概念和问题,经常会被混淆. 求最短路径长度的常用算法是 Dijkst ...
 - Python 图_系列之纵横对比  Bellman-Ford 和  Dijkstra 最短路径算法
		
1. 前言 因无向.无加权图的任意顶点之间的最短路径由顶点之间的边数决定,可以直接使用原始定义的广度优先搜索算法查找. 但是,无论是有向.还是无向,只要是加权图,最短路径长度的定义是:起点到终点之间所 ...
 - Johnson 全源最短路径算法
		
解决单源最短路径问题(Single Source Shortest Paths Problem)的算法包括: Dijkstra 单源最短路径算法:时间复杂度为 O(E + VlogV),要求权值非负: ...
 
随机推荐
- 【BZOJ 2453】 维护队列
			
[题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=2453 [算法] 带修改的莫队算法 当块的大小为N^(2/3)时,时间复杂度为 : O ...
 - Weex学习与实践(一):Weex,你需要知道的事
			
Weex学习与实践(一):Weex,你需要知道的事 http://coderyi.com/posts/weex1/ 1.命令行工具:weex-toolkit https://github.com/w ...
 - linux下解决非本机访问出现的提示
			
安装完毕之后发现无法用IP访问,出现以下提示 Access forbidden! New XAMPP security concept: Access to the requested directo ...
 - 两个TableView产生联动的一中方法
			
如何使用两个TableView产生联动:将两个tableView的滚动事件禁止掉,最外层scrollView滚动时将两个TableView跟着滚动,并且更改contentOffset,这样产生效果滚动 ...
 - FLAG_DISMISS_KEYGUARD & FLAG_SHOW_WHEN_LOCKED
			
getWindow().addFlags(WindowManager.LayoutParams.FLAG_DISMISS_KEYGUARD): 这一个标志的意思是去掉锁屏界面,但这对安全锁(图案或者密 ...
 - java中拦截器 过滤器 监听器都有什么区别
			
过滤器,是在java web中,你传入的request,response提前过滤掉一些信息,或者提前设置一些参数,然后再传入servlet或者struts2的action进行业务逻辑,比如过滤掉非法u ...
 - hadoop配置历史服务器
			
此文档不建议当教程,仅供参考 配置历史服务器 我是在hadoop1机器上配置的 配置mapred-site.xml <property> <name>mapreduce.job ...
 - 【转自网络】JS实现保存当前网页HTML到本地
			
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
 - SpringBoot(十)  异步任务,定时任务和邮件任务
			
异步任务 “异步调用”对应的是“同步调用”,同步调用指程序按照定义顺序依次执行,每一行程序都必须等待上一行程序执行完成之后才能执行:异步调用指程序在顺序执行时,不等待异步调用的语句返回结果就执行后面的 ...
 - js判断PC端与移动端跳转
			
在网上看到很多这样类似的代码,但是有的很复杂,或者有的没有判断完全,上次经理去见完客户回来讲,使用苹果浏览打开pc端(pc已经做了识别跳转)会自动跳转到移动端的网页去,后来经测试才发现 documen ...