У меня есть две структуры, содержащие некоторые поля: struct MyNodeData и struct MyEdgeData.Когда я создаю граф с VertexList в качестве vecS, нет проблем с доступом к дескриптору вершин и т. Д. Например:
typedef adjacency_list<setS, vecS, undirectedS, MyNodeData, MyEdgeData> Graph;
typedef Graph::vertex_descriptor MyNodeDataID;
typedef Graph::edge_descriptor MyEdgeDataID;
typedef graph_traits < Graph >::vertex_iterator VertexIterator;
typedef graph_traits < Graph >::edge_iterator EdgeIterator;
typedef graph_traits < Graph >::adjacency_iterator AdjacencyIterator;
typedef property_map < Graph, vertex_index_t >::type IndexMap;
Graph g;
const IndexMap index = get(vertex_index, g);
/* Puis après avoir ajouté des vertex et edges, je peux accéder par exemple à la liste des vertex comme suite: */
pair<VertexIterator, VertexIterator> vi;
for(vi = vertices(g); vi.first != vi.second; ++vi.first)
{
cout << "vertex: " << index[*vi.first] << endl;
// or: cout << "vertex: " << *vi.first << endl;
}
Но мне обычно нужно добавлять / удалять ребра и вершины из моего графа.Поэтому я хочу использовать setS или listS в качестве VertexList вместо vecS, поскольку с vecS индексы становятся недействительными, когда мы удаляем один из них!Проблема в том, что если я определю VertexList как setS или listS, я не смогу просмотреть список вершин / ребер и получить доступ к дескрипторам там, как я это делал раньше!
Чтобы сделать его коротким, мой вопрос:который использует listS или setS в качестве контейнера вершин, автоматически не предоставляет это свойство vertex_id, как я могу добавить его в приведенный выше код?