C++ Boost graph 深度(广度)优先算法示例

原创 2005年02月25日 16:50:00

//整理 by  RobinKin from DevonIT.inc
#include <boost/config.hpp>
#include <iostream>
#include <vector>
#include <string>
#include <boost/graph/adjacency_list.hpp>
#include <boost/graph/depth_first_search.hpp>
#include <boost/graph/breadth_first_search.hpp>
#include <boost/property_map.hpp>
#include <boost/graph/graph_utility.hpp> // for boost::make_list


/*
  Example of using a visitor with the depth first search
    and breadth first search algorithm

  Sacramento ---- Reno ---- Salt Lake City
     |
  San Francisco
     |
  San Jose ---- Fresno
     |
  Los Angeles ---- Los Vegas ---- Pheonix
     |
  San Diego 


  The visitor has three main functions:
 
  discover_vertex(u,g) is invoked when the algorithm first arrives at the
    vertex u. This will happen in the depth first or breadth first
    order depending on which algorithm you use.

  examine_edge(e,g) is invoked when the algorithm first checks an edge to see
    whether it has already been there. Whether using BFS or DFS, all
    the edges of vertex u are examined immediately after the call to
    visit(u).

  finish_vertex(u,g) is called when after all the vertices reachable from vertex
    u have already been visited.   

*/

using namespace std;
using namespace boost;

//到达结点时 operator()

struct city_arrival : public base_visitor<city_arrival>
{
  city_arrival(string* n) : names(n) { }
  typedef on_discover_vertex event_filter;
  template <class Vertex, class Graph>
  inline void operator()(Vertex u, Graph&) {
    cout << endl << "arriving at " << names[u] << endl
         << "  neighboring cities are: ";
  }
  string* names;
};

//显示邻接结点时 。调用 operator()
struct neighbor_cities : public base_visitor<neighbor_cities>
{
  neighbor_cities(string* n) : names(n) { }
  typedef on_examine_edge event_filter;
  template <class Edge, class Graph>
  inline void operator()(Edge e, Graph& g) {
    cout << names[ target(e, g) ] << ", ";
  }
  string* names;
};

//某结点的所有邻接结点都已经被访问过时  调用 operator()

struct finish_city : public base_visitor<finish_city>
{
  finish_city(string* n) : names(n) { }
  typedef on_finish_vertex event_filter;
  template <class Vertex, class Graph>
  inline void operator()(Vertex u, Graph&) {
    cout << endl << "finished with " << names[u] << endl;
  }
  string* names;
};

int main(int, char*[])
{

  enum { SanJose, SanFran, LA, SanDiego, Fresno, LosVegas, Reno,
         Sacramento, SaltLake, Pheonix, N };

  string names[] = { "San Jose", "San Francisco",  "San Jose",
                     "San Francisco", "Los Angeles", "San Diego",
                     "Fresno", "Los Vegas", "Reno", "Sacramento",
                     "Salt Lake City", "Pheonix" };

  typedef std::pair<int,int> E;
  E edge_array[] = { E(Sacramento, Reno), E(Sacramento, SanFran),
                     E(Reno, SaltLake),
                     E(SanFran, SanJose),
                     E(SanJose, Fresno), E(SanJose, LA),
                     E(LA, LosVegas), E(LA, SanDiego),
                     E(LosVegas, Pheonix) };

  /* Create the graph type we want. */
  typedef adjacency_list<vecS, vecS, undirectedS> Graph;

  Graph G(edge_array, edge_array + sizeof(edge_array)/sizeof(E), N);


  cout << "*** Depth First ***" << endl;

//第 1 2 3 个参数分别是 arrival neighbor  finish
  depth_first_search
    (G,
     visitor(make_dfs_visitor(boost::make_list(city_arrival(names),
                                               neighbor_cities(names),
                                               finish_city(names)))));
  cout << endl;

  /* Get the source vertex */
  boost::graph_traits<Graph>::vertex_descriptor
    s = vertex(SanJose,G);

  cout << "*** Breadth First ***" << endl;
  breadth_first_search
    (G, s, visitor(make_bfs_visitor(boost::make_list(city_arrival(names),
                                                     neighbor_cities(names),
                                                     finish_city(names)))));
 
  return 0;
}


//输出:
*** Depth First ***

arriving at San Jose
  neighboring cities are: San Francisco,
arriving at San Francisco
  neighboring cities are: Los Vegas,
arriving at Los Vegas
  neighboring cities are: Fresno,
arriving at Fresno
  neighboring cities are: Los Vegas, Reno,
arriving at Reno
  neighboring cities are: Fresno,
finished with Reno

finished with Fresno
San Francisco,
finished with Los Vegas
San Jose,
finished with San Francisco
Los Angeles,
arriving at Los Angeles
  neighboring cities are: San Jose,
finished with Los Angeles

C++实现图算法(一)

图算法(一) 对图的顶点和边进行了封装。
  • aiversonwk
  • aiversonwk
  • 2011年03月21日 16:24
  • 8381

C++ 图的实现

图可以说是算法与数据结构中十分重要的一个部分,然而对于图的实现,还是有一点点繁琐,今天参考清华大学出版社《数据结构》一书进行了一些回顾,记录于此。 本文并不对基本概念进行过多探讨,而着眼于实现。基于...
  • zhangyalin1992
  • zhangyalin1992
  • 2014年05月06日 20:26
  • 8381

图的表示方法 c++ 实现

图的表示最长用的两种方法是: 1)、邻接矩阵表示法 2)、邻接表表示 下面是两种构造图的方法 1)邻接矩阵: 2)邻接链表 #include using namespace std; //枚举...
  • xlf13872135090
  • xlf13872135090
  • 2013年12月26日 14:23
  • 10992

c++graph类

  • 2013年08月27日 18:20
  • 30KB
  • 下载

使用C++ Boost Graph Library 进行社交网络分析入门篇

前言:      社交网络分析是一个常常会遇到的业务问题,故而笔者也一致在不断尝试不同的社交网络分析工具。之前使用过python networkx, igraph C library, 今日再介...
  • a_step_further
  • a_step_further
  • 2016年05月30日 11:19
  • 1346

Boost中的图(1)

图的存储结构可以有邻接矩阵,邻接表,十字链表,多重链表一.图的邻接表表示1.邻接表adjacency_list的类模板adjacency_list OutEdgeList 表示出边容器类,可以是vec...
  • mmhhj
  • mmhhj
  • 2017年03月14日 22:42
  • 334

Boost和AdaBoost算法原理简介

本文主要参考: 1):《AdaBoost分类算法》http://wenku.baidu.com/link?url=udZ32_5hjlVNuqOAhuCEDPpHcQTEwEAxBiPkkPmPSM...
  • whiteinblue
  • whiteinblue
  • 2013年11月08日 11:06
  • 9145

几种Boost算法的比较

转自:http://www.cnblogs.com/jcchen1987/p/4581651.html 关于boost算法   boost算法是基于PAC学习理论(probab...
  • xuxiatian
  • xuxiatian
  • 2016年12月12日 14:55
  • 3157

Boost Graph Library 快速入门

Boost Graph Library 快速入门 图领域的数据结构和算法在某些方面比容器更为复杂,图算法在图中移动有着众多的路线,而STL使用的抽象迭代器接口不能有效的支持这些。作为替换,我们为...
  • seamanj
  • seamanj
  • 2016年02月05日 02:13
  • 1191

介绍几个图论和复杂网络的程序库 —— BGL,QuickGraph,igraph和NetworkX

作复杂网络研究离不开对各种实际或模拟网络的统计、计算、绘图等工作。对于一般性的工作,我们可以用Pajek、Netdraw和Ucinet等软件完成。但对一些特殊应用(比如自己开发了一个新模型),现有的软...
  • a358463121
  • a358463121
  • 2016年05月04日 23:19
  • 2443
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:C++ Boost graph 深度(广度)优先算法示例
举报原因:
原因补充:

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