長いコードで申し訳ありませんが、エラーを見つけようとしていて、実際には見つかりません。実行しようとするとエラーが発生します。
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);
誰かが私に解決策を提供できれば、本当に感謝しています。