【发布时间】:2014-04-16 14:58:25
【问题描述】:
下面是代码。更多相关位位于 Class Edge 和 Vertex 下,错误抛出复制构造函数位于初始块下方。 我确定这与我调用 end 和 start 的方式有关,看看它们在 Edge() 类中的 Vertex* 类型如何,并且我使用 std:: 类型的迭代器调用它们矢量::边*>。这是基于指针的东西。 是的,这是针对课堂的,但这是一个包含更多内容的课堂项目,这只是我遇到的一个错误。提前谢谢,我可能只是因为睡眠不足或其他原因而没有看到明显的东西。
#ifndef GRAPH_H
#define GRAPH_H
#include <vector>
#include <limits>
#include <string>
#include <iostream>
#include <fstream>
using namespace std;
template <typename Object, typename Weight>
class graph {
public:
class Vertex;
class Edge {
public:
Edge(Vertex* v, Vertex* w, Weight setweight) {
start = v;
end = w;
v->edge.push_back(this);
w->inedge.push_back(this);
weight = setweight;
explored = false;
}
Edge() {
explored = false;
}
Weight weight;
Vertex* start;
Vertex* end;
bool explored;
};
class Vertex {
public:
Vertex(Object setelement) {
level = 0;
connectedcomponent = 0;
element = setelement;
back = NULL;
explored = false;
}
Vertex() {
level = 0;
connectedcomponent = 0;
back = NULL;
explored = false;
}
Object element;
vector<Edge*> edge;
vector<Edge*> inedge;
double value;
size_t starttime, finishtime;
size_t level;
size_t connectedcomponent;
float rank;
Vertex* back;
int color;
bool explored;
};
private:
vector<Edge*> edge;
vector<Vertex*> vertex;
size_t counter;
public:
graph();
graph(graph& G);
~graph();
void reset();
void resetBack();
void resetValues();
void resetLevels();
void resetExplored();
void resetConnectedComponents();
vector<Vertex*> incidentVertices(Vertex* v);
vector<Edge*> incidentEdges(Vertex* v);
vector<Edge*> outgoingEdges(Vertex* v);
vector<Vertex*> adjacentVertices(Vertex* v);
size_t indegree(Vertex* v);
size_t outdegree(Vertex* v);
size_t degree(Vertex* v);
Vertex* startVertex(Edge* e);
Vertex* endVertex(Edge* e);
bool isAdjacent(Vertex* v, Vertex* w);
Vertex* insertVertex(Object o);
void insertEdge(Vertex* v, Vertex* w, Weight t);
void insertUndirectedEdge(Vertex* v, Vertex* w, Weight t);
void removeVertex(Vertex* v);
void removeEdge(Edge* e);
size_t numVertices();
size_t numEdges();
vector<Vertex*> vertices();
vector<Edge*> edges();
void print();
void read_file(std::string filename);
};
template <typename Object, typename Weight>
graph<Object, Weight>::graph() {//Default Constructor
Edge();
Vertex();
counter = 0;
}
复制构造函数,它会生成错误(我知道这是基于迭代器的)
Graph.h:149:22: 错误:‘std::vector::Edge*, std::allocator::Edge*> >::iterator’没有名为‘start’的成员 查找(it_edge.start),查找(it_edge.end),(*(it_edge))->重量)); ^
Graph.h:149:40: 错误:‘std::vector::Edge*, std::allocator::Edge*> >::iterator’没有名为‘end’的成员 查找(it_edge.start),查找(it_edge.end),(*(it_edge))->重量)); ^
template <typename Object, typename Weight>
graph<Object, Weight>::graph(graph<Object, Weight>& G) {//Copy Constructor
typename std::vector<graph<Object, Weight>::Vertex*>::iterator it_vert;
for(it_vert = vertex.begin(); it_vert != vertex.end(); ++it_vert){
vertex.push_back(new Vertex((*(it_vert))->element));
}
typename std::vector<graph<Object, Weight>::Edge*>::iterator it_edge;
for(it_edge = edge.begin(); it_edge != edge.end(); ++it_edge){
edge.push_back(new Edge(
find(it_edge.start),find(it_edge.end),(*(it_edge))->weight));
}
}
【问题讨论】:
-
我试过了,但得到了 Graph.h:149:23: error: request for member 'start' in '* it_edge.__gnu_cxx::__normal_iterator<_iterator _container>::operator->::Edge**, std::vector
::Edge*, std::allocator ::Edge*> > ()',它是指针类型'graph ::Edge*' 我已经没有关于此时应该如何调用 start 或 end 的想法 -
也许你可以使用boost图形库?它有很多处理图表的工具。
-
@user3210680 嗯,似乎有一些来自 ref 返回的迭代器的干扰。
(*it_edge)->start有效。我会尝试找出为什么我原来的建议不起作用。
标签: c++ class pointers graph iterator