我使用的是升级图,似乎我不太了解它。
要访问顶点的标签,似乎可以使用get(vertex_name,graph_)然后使用[]访问它。 但是如何访问边缘的标签。
我尝试应用相同的方法(以及许多其他错误的东西)但是 我没有成功访问其标签。
以下是我的代码片段:
typedef property<edge_name_t, int> edge_property;
typedef property<vertex_name_t, int> vertex_property;
typedef adjacency_list<vecS, vecS, undirectedS, vertex_property, edge_property> MyGraph;
MyGraph graph_;
add_vertex(vertex_property(6), graph_);
add_vertex(vertex_property(1), graph_);
add_vertex(vertex_property(1), graph_);
add_edge(0, 1, edge_property(2), graph_);
add_edge(1, 2, edge_property(3), graph_);
add_edge(0, 2, edge_property(1), graph_);
cout << "Graph 1 [graph_]" << endl;
typedef graph_traits<MyGraph>::edge_iterator edge_iter;
pair<edge_iter, edge_iter> ep;
property_map<MyGraph, vertex_name_t>::type labelling_vertex = get(vertex_name, graph_);
property_map<MyGraph, edge_name_t>::type labelling_edge = get(edge_name, graph_);
int position = 0;
for (ep = edges(graph_); ep.first != ep.second; ++ep.first) {
unsigned int source_ = source(*ep.first, graph_);
unsigned int target_ = target(*ep.first, graph_);
cout << source_ << "["<< labelling_vertex[source_] <<"]" << " ~~~~" << labelling_edge[position] << "~~~~ " << target_ <<"[" <<labelling_vertex[target_] <<"]" << endl;
position++;
}
答案 0 :(得分:0)
好的,刚刚找到了办法。
labelling_edge [(* ep.first)]
很抱歉打扰了你