adjacency_matrix.cpp

来自「Boost provides free peer-reviewed portab」· C++ 代码 · 共 68 行

CPP
68
字号
//=======================================================================// Copyright 1997, 1998, 1999, 2000 University of Notre Dame.// Author: 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 <boost/graph/adjacency_matrix.hpp>#include <boost/graph/graph_utility.hpp>int main(){  using namespace boost;  enum { A, B, C, D, E, F, N };  const char* name = "ABCDEF";  // A directed graph    typedef adjacency_matrix<directedS> Graph;  Graph g(N);  add_edge(B, C, g);  add_edge(B, F, g);  add_edge(C, A, g);  add_edge(C, C, g);  add_edge(D, E, g);  add_edge(E, D, g);  add_edge(F, A, g);  std::cout << "vertex set: ";  print_vertices(g, name);  std::cout << std::endl;  std::cout << "edge set: ";  print_edges(g, name);  std::cout << std::endl;  std::cout << "out-edges: " << std::endl;  print_graph(g, name);  std::cout << std::endl;  // An undirected graph  typedef adjacency_matrix<undirectedS> UGraph;  UGraph ug(N);  add_edge(B, C, ug);  add_edge(B, F, ug);  add_edge(C, A, ug);  add_edge(D, E, ug);  add_edge(F, A, ug);  std::cout << "vertex set: ";  print_vertices(ug, name);  std::cout << std::endl;  std::cout << "edge set: ";  print_edges(ug, name);  std::cout << std::endl;  std::cout << "incident edges: " << std::endl;  print_graph(ug, name);  std::cout << std::endl;  return 0;}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?