kevin-bacon.cpp
来自「Boost provides free peer-reviewed portab」· C++ 代码 · 共 118 行
CPP
118 行
//=======================================================================// Copyright 2001 Jeremy G. Siek, Andrew Lumsdaine, Lie-Quan Lee, //// 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 <fstream>#include <string>#include <boost/tokenizer.hpp>#include <boost/tuple/tuple.hpp>#include <boost/graph/adjacency_list.hpp>#include <boost/graph/visitors.hpp>#include <boost/graph/breadth_first_search.hpp>#include <map>using namespace boost;template <typename DistanceMap>class bacon_number_recorder : public default_bfs_visitor{public: bacon_number_recorder(DistanceMap dist) : d(dist) { } template <typename Edge, typename Graph> void tree_edge(Edge e, const Graph& g) const { typename graph_traits<Graph>::vertex_descriptor u = source(e, g), v = target(e, g); d[v] = d[u] + 1; }private: DistanceMap d;};// Convenience functiontemplate < typename DistanceMap >bacon_number_recorder<DistanceMap>record_bacon_number(DistanceMap d){ return bacon_number_recorder < DistanceMap > (d);}intmain(){ std::ifstream datafile("./kevin-bacon.dat"); if (!datafile) { std::cerr << "No ./kevin-bacon.dat file" << std::endl; return EXIT_FAILURE; } typedef adjacency_list < vecS, vecS, undirectedS, property < vertex_name_t, std::string >, property < edge_name_t, std::string > > Graph; Graph g; typedef property_map < Graph, vertex_name_t >::type actor_name_map_t; actor_name_map_t actor_name = get(vertex_name, g); typedef property_map < Graph, edge_name_t >::type movie_name_map_t; movie_name_map_t connecting_movie = get(edge_name, g); typedef graph_traits < Graph >::vertex_descriptor Vertex; typedef std::map < std::string, Vertex > NameVertexMap; NameVertexMap actors; for (std::string line; std::getline(datafile, line);) { char_delimiters_separator < char >sep(false, "", ";"); tokenizer <> line_toks(line, sep); tokenizer <>::iterator i = line_toks.begin(); std::string actors_name = *i++; NameVertexMap::iterator pos; bool inserted; Vertex u, v; tie(pos, inserted) = actors.insert(std::make_pair(actors_name, Vertex())); if (inserted) { u = add_vertex(g); actor_name[u] = actors_name; pos->second = u; } else u = pos->second; std::string movie_name = *i++; tie(pos, inserted) = actors.insert(std::make_pair(*i, Vertex())); if (inserted) { v = add_vertex(g); actor_name[v] = *i; pos->second = v; } else v = pos->second; graph_traits < Graph >::edge_descriptor e; tie(e, inserted) = add_edge(u, v, g); if (inserted) connecting_movie[e] = movie_name; } std::vector < int >bacon_number(num_vertices(g)); Vertex src = actors["Kevin Bacon"]; bacon_number[src] = 0; breadth_first_search(g, src, visitor(record_bacon_number(&bacon_number[0]))); graph_traits < Graph >::vertex_iterator i, end; for (tie(i, end) = vertices(g); i != end; ++i) { std::cout << actor_name[*i] << " has a Bacon number of " << bacon_number[*i] << std::endl; } return 0;}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?