topo_sort.cpp
来自「Boost provides free peer-reviewed portab」· C++ 代码 · 共 75 行
CPP
75 行
//=======================================================================// Copyright 1997, 1998, 1999, 2000 University of Notre Dame.// Authors: Andrew Lumsdaine, Lie-Quan Lee, Jeremy G. Siek//// Distributed under the Boost Software License, Version 1.0. (See// accompanying file LICENSE_1_0.txt or copy at// http://www.boost.org/LICENSE_1_0.txt)//=======================================================================#include <boost/config.hpp>#include <iostream>#include <list>#include <algorithm>#include <boost/graph/adjacency_list.hpp>#include <boost/graph/topological_sort.hpp>#include <iterator>#include <utility>typedef std::pair<std::size_t,std::size_t> Pair;/* Topological sort example The topological sort algorithm creates a linear ordering of the vertices such that if edge (u,v) appears in the graph, then u comes before v in the ordering. Sample output: A topological ordering: 2 5 0 1 4 3*/intmain(int , char* []){ //begin using namespace boost; /* Topological sort will need to color the graph. Here we use an internal decorator, so we "property" the color to the graph. */ typedef adjacency_list<vecS, vecS, directedS, property<vertex_color_t, default_color_type> > Graph; typedef boost::graph_traits<Graph>::vertex_descriptor Vertex; Pair edges[6] = { Pair(0,1), Pair(2,4), Pair(2,5), Pair(0,3), Pair(1,4), Pair(4,3) };#if defined(BOOST_MSVC) && BOOST_MSVC <= 1300 // VC++ can't handle the iterator constructor Graph G(6); for (std::size_t j = 0; j < 6; ++j) add_edge(edges[j].first, edges[j].second, G);#else Graph G(edges, edges + 6, 6);#endif boost::property_map<Graph, vertex_index_t>::type id = get(vertex_index, G); typedef std::vector< Vertex > container; container c; topological_sort(G, std::back_inserter(c)); std::cout << "A topological ordering: "; for (container::reverse_iterator ii = c.rbegin(); ii != c.rend(); ++ii) std::cout << id[*ii] << " "; std::cout << std::endl; return 0;}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?