0

私は2つの構造を持っています

struct Edge{
        int v1;
    int v2;
        int weigt;

    Edge(int v1_tmp, int v2_tmp, int weight_tmp);
};

struct GraphList{
        int V;
    int E;
    list<Edge>* mylist;
}

GraphList::GraphList(GrafMatrix* graph){
    V=graph->V;
    E=graph->E;

    for (int i=0; i<V; i++){
        for (int j=0; j<V; j++){
            if (graph->matrix[i][j]==1) mylist[i].push_back( Edge(i+1, j+1, graf->weights[i][j]) );
        }
    }
}

どうしたの?i=0との場合j=1、エラーがあります。試しlista = new list<Krawedz>()ましたが、うまくいきません。何か案は?

4

1 に答える 1

2

スペースが割り当てられていないポインターを逆参照しています。注意してくださいlist<Edge>* mylistnewとして使用する必要があります

mylist = new list<Edge>[k];  //declare an array of k list<Edge>.

次に、mylist[0] 、....、mylist[k-1] にアクセスできるようになります。

于 2013-05-31T19:44:46.510 に答える