对于冗长的代码,我深表歉意,但我一直试图找出错误,但真的找不到。当我尝试运行它时出现错误。
void setADist(vector<Facility> &vFac, vector<Client> &vClient, vector<Edge> &vEdge, vector<Node> &vNode){
...
vector<Edge> temp(vEdge);
float *distance;
...
temp.push_back(Edge(101, 101, facEndNode, py(vFac[i].getLongitude(), x, vFac[i].getLatitude(), y)));
Graphs *g1 = new Graphs();
struct Graph* graph1 = g1->createGraph(temp.size());
for (int k = 0; k < temp.size(); k++){
//g1->addEdge(graph1, temp[k].getStartNode(), temp[k].getEndNode(), temp[k].getDist()); //THIS LINE CAUSES THE EXCEPTION
}
//g1->printGraph(graph1);
//distance = g1->dijkstra(graph1, vFac[i].getNodeID());
}
}
}
}
当我调用该方法时,注释行会导致异常。
我尝试在 main() 中分别运行以下代码,但没有发现异常,因此它与类 Graphs 没有任何关系。
Graphs *g = new Graphs();
struct Graph* graph = g->createGraph(vEdge.size());
for (int i = 0; i < vEdge.size(); i++){
g->addEdge(graph, vEdge[i].getStartNode(), vEdge[i].getEndNode(), vEdge[i].getDist());
}
//g->printGraph(graph);
如果有人可以为我提供解决方案,我将不胜感激。