0

对于冗长的代码,我深表歉意,但我一直试图找出错误,但真的找不到。当我尝试运行它时出现错误。

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);

如果有人可以为我提供解决方案,我将不胜感激。

4

0 回答 0