Boost dijkstra 单元最段路径示例

原创 2005年02月25日 17:52:00

//整理 by RobinKin  from DevonIT

#include <boost/config.hpp>
#include <iostream>
#include <fstream>

#include <boost/graph/graph_traits.hpp>
#include <boost/graph/adjacency_list.hpp>
#include <boost/graph/dijkstra_shortest_paths.hpp>

using namespace boost;

int
main(int, char *[])
{
  typedef adjacency_list < listS, vecS, directedS,
    no_property, property < edge_weight_t, int > > graph_t;
  typedef graph_traits < graph_t >::vertex_descriptor vertex_descriptor;
  typedef graph_traits < graph_t >::edge_descriptor edge_descriptor;
  typedef std::pair<int, int> Edge;

  const int num_nodes = 5;
  enum nodes { A, B, C, D, E };
  char name[] = "ABCDE";
  Edge edge_array[] = { Edge(A, C), Edge(B, B), Edge(B, D), Edge(B, E),
    Edge(C, B), Edge(C, D), Edge(D, E), Edge(E, A), Edge(E, B)
  };
 
  int weights[] = { 1, 2, 1, 2, 7, 3, 1, 1, 1 };

  int num_arcs = sizeof(edge_array) / sizeof(Edge);
 
  graph_t g(edge_array, edge_array + num_arcs, weights, num_nodes);
 
  property_map<graph_t, edge_weight_t>::type weightmap = get(edge_weight, g);
 
  std::vector<vertex_descriptor> p(num_vertices(g));//前驱结点
  std::vector<int> d(num_vertices(g));    //距离
  vertex_descriptor s = vertex(A, g);  //源点是A

//从A开始计算最短路径

  dijkstra_shortest_paths(g, s, predecessor_map(&p[0]).distance_map(&d[0]));

  std::cout << "distances and parents:" << std::endl;
  graph_traits < graph_t >::vertex_iterator vi, vend;
  for (tie(vi, vend) = vertices(g); vi != vend; ++vi) {
    std::cout << "distance(" << name[*vi] << ") = " << d[*vi] << ", ";
    std::cout << "parent(" << name[*vi] << ") = " << name[p[*vi]] << std::
      endl;
  }

  return EXIT_SUCCESS;
}

//输出:

distances and parents:
distance(A) = 0, parent(A) = A
distance(B) = 6, parent(B) = E
distance(C) = 1, parent(C) = A
distance(D) = 4, parent(D) = C
distance(E) = 5, parent(E) = D

Dijkstra算法(单元点最短路径)

Dijkstra算法解决图中某特定点到其他点的最短路径。 迪杰斯塔拉(Dijkstra)算法思想: 按路径长度递增的次序产生最短路径的算法。设集合S存放已经找到最短路径的顶点,V为所有节点的集合,...
  • xiaolei09bupt
  • xiaolei09bupt
  • 2015年04月27日 10:42
  • 751

Dijkstra最短路径算法(SPF)

算法描述: Dijkstra算法是一种求单源最短路的算法,即从一个点开始到所有其他点的最短路。其基本原理是:每次新扩展一个距离最短的点,更新与其相邻的点的距离。当所有边权都为正时,由于不会存在一...
  • ZLhy_
  • ZLhy_
  • 2012年12月04日 22:42
  • 10760

【漫漫科研路\Matlab】最小跳数最大权重算法

上周,实验室国际友人让我帮忙实现满足条件的最小跳数最大权重的算法。他的具体问题如下: 给定一个权重图(如下图所示),给出节点之间最小跳数最大权重矩阵,其中任意两点之间跳数小于等于3,否则权重为inf...
  • tengweitw
  • tengweitw
  • 2017年12月17日 16:38
  • 233

单元Dijkstra算法求最短路径的的Java实现

上一篇写了无权值的最短路径的求法,是利用广度优先搜索的方法使用队列实现的,当有权值时,我们通常使用Dijkstra算法来求解最短路径的问题,这里我们假设所有的权值都是正值。 首先,在节点类改变了权值的...
  • qq_20991785
  • qq_20991785
  • 2015年03月17日 11:08
  • 866

单源最短路径( Dijkstra算法)JAVA实现

单源最短路径问题,即在图中求出给定顶点到其它任一顶点的最短路径。在弄清楚如何求算单源最短路径问题之前,必须弄清楚最短路径的最优子结构性质。 一.最短路径的最优子结构性质    该性质描述为...
  • gloria0610
  • gloria0610
  • 2014年04月15日 10:40
  • 4973

hdu3790 - 最短路径问题 (Dijkstra)(多条最短路径找花费最少的一条)

最短路径问题 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total S...
  • u012727619
  • u012727619
  • 2014年08月29日 19:00
  • 1075

浅谈:狄克斯特拉算法Dijkstra找最小树问题

6.3.1狄克斯特拉算法(Dijkstra  algorithm, 1959)          计算两节点之间或一个节点到所有节点之间的最短路 •对每个节点,用两种标号:T和P,表示从始点到...
  • qq_26512631
  • qq_26512631
  • 2015年08月06日 17:04
  • 678

最短路(Dijkstra)

算法过程 1.设置顶点集合S并不断的作贪心选择来选择扩充这个集合。一个顶点属于集合S当且仅当从源点到该点的最短路径长度已知 2.初始时,S中仅含有源。设U是G的某一个顶点,把从源到U且中间只经过S中的...
  • booyoungxu
  • booyoungxu
  • 2015年07月28日 18:52
  • 1276

最短路径 输出路径 Dijkstra算法

某个源点到其余各顶点的最短路径 这个算法最开始心里怕怕的,不知道为什么,花了好长时间弄懂了,也写了一遍,又遇到时还是出错了,今天再次写它,心里没那么怕了,耐心研究,懂了之后会好开心的,哈哈Dijkst...
  • qq_36183935
  • qq_36183935
  • 2017年04月03日 20:38
  • 1959

单源多点最短路径-Dijkstra算法

Dijkstra算法使用了贪心算法思想,在实现Dijkstra算法的时候,维持一个节点的集合S,该集合节点到源点的最短路径都已经找到;而对于S集合之外的节点,放置在集合Q中,表示还没有找到最短路径的节...
  • u010726042
  • u010726042
  • 2016年04月16日 21:52
  • 1171
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Boost dijkstra 单元最段路径示例
举报原因:
原因补充:

(最多只允许输入30个字)