-2

非常感谢您的评论,我是新来的,不熟悉协议。这是我的完整示例。这就是我在执行时得到的

在顶点 ctor 加载顶点 [0] = xxx 在顶点 ctor 加载顶点 [1] = xxx 在顶点 ctor 加载顶点 [2] = xxx 在顶点 ctor 加载顶点 [3] = xxx 在顶点 ctor 加载顶点 [4] = xxx in vertex ctor loading vertex[ 5] = xxx in vertex ctor loading vertex[ 0] = xxx calculateCosts got vertex named xxx move vertex named xxx done 分割错误

    #include <iostream> 
#include <vector>   
#include <cassert>  
#include <limits>
#include <initializer_list>
#include <iterator>

// required compile option g++ homeWork2.cpp -std=c++0x

using namespace std;

const int infinity = numeric_limits<int>::infinity();
//const   vertex* nullPtr = 0;

class vertex
{
public:
    string name;
    vertex(string name = "undefined")
    {
        cout << "in vertex ctor " << endl;
        name = "AAAAAA";
        value = infinity;
        prev_vertex = NULL;
    }
    void set_value(int& value)
    {
        assert(value > 0);
        value = value;
    }
    int get_value()
    {
        return value;
    }
    void set_prev_vertex(vertex& prev_vertex)
    {
        prev_vertex = prev_vertex;
    }
    vertex* get_prev_vertex()
    {
        return prev_vertex;
    }

private:
    int value;
    vertex * prev_vertex;
};


class graph
{
public:
    graph(int graphSize = 50)
    {
        for (int i = 0; i < graphSize; ++i)
        {
            vertex* pV = new vertex("vertex name");
            pV->name = "xxx";
            cout << "loading vertex[ " << i << "] = " << pV->name << endl;
            vertices.push_back(pV);
        }
    }

//    vector<vertex> get_neighbors(int i);

    void push_Vertex(unsigned position, vertex* v);
    void remove_Vertex(unsigned position);
    vertex* get_Vertex(unsigned position);
    int size();
    vector<vertex*> get_neighbors(int i);

    ~graph()
    {
        while (vertices.size() > 0)
        {
//          cout << "removing vertices[ " << vertices.size() << "] = " << vertices.back() << endl;
            delete vertices.back();
            vertices.pop_back();
        }
    }

private:
    int graph_count;
    vector<vertex*> vertices;
};

void graph::push_Vertex(unsigned position, vertex* v)
{
//      cout << "copying vertex named " << *v->name << endl;
//        assert(v!=NULL);
        vertices[position] = v;
//      vertices.push_back(v);
}
void graph::remove_Vertex(unsigned position)
{
    vertices.erase(vertices.begin()+position);
}
vertex* graph::get_Vertex(unsigned position)
{
//  vector<int>::iterator iter = vertices.begin()+=position;
    vertex* pV = vertices.at(position);
    cout << "got vertex named " << pV->name << endl;
    return pV;
}

vector<vertex*> graph::get_neighbors(int i)
{
    vector<vertex*> vertices;
    /* load the it neighbors*/
    return vertices;
}

int graph::size()
{
    return vertices.size();
}

void moveVertex(graph& fromSet, graph& toSet, int position, int value)
{
    vertex* v = fromSet.get_Vertex(position);
    cout << "moving vertex named " << v->name << endl;
    toSet.push_Vertex(0, v);

}

void calculateCosts(graph& unvisitedSet, graph& visitedSet)
{
    moveVertex(unvisitedSet, visitedSet, 0, 0);
    for (int i =0; i < unvisitedSet.size(); ++i) {
//  do the algo process ...        
    }
}

// 
int main()
{

//    adjacency_list adjList = adjacency_list(6);
//    cost_list costList = cost_list(6);
    graph visitedSet = graph(6);
    graph unvisitedSet = graph(1);
    cout << "calculateCosts" << endl;
    calculateCosts(visitedSet, unvisitedSet);

    cout << "done" << endl;

    return 0;
}
4

1 回答 1

2
        vertex* v = new vertex("vertex nbr "+i);

在 C++ 中,您不能使用operator+onconst char*int. 必须以其他方式构造字符串。我很惊讶编译器没有写一个警告,更不用说停在那里了。

编辑:我现在看到“calculateCosts 移动顶点名为完成分段错误”这一行。很不起眼,第一次也没注意,现在看是程序的输出。似乎导致分段错误的代码位于析构函数之一中。您的调试器是否具有在发生段错误时暂停执行的功能?能开机吗?你能逐步调试你的代码,包括析构函数中的代码吗?如果一步一步调试会发生什么?

非常重要:vertex构造函数和析构函数是什么样的?

这篇文章应该提供一个答案,但我给你更多的问题。那是因为您自己的问题缺乏相关信息。您提供了一些代码,这很好,但我无法编译该代码来重现错误。努力将您的示例代码减少到重现错误的最低限度。这可能需要很长时间,而且您很可能会自己发现问题。那将是完美的结果。

于 2013-11-02T13:53:49.773 回答