Создать график, используя список смежности - PullRequest
2 голосов
/ 20 апреля 2010
#include<iostream>

using namespace std;

class TCSGraph{
    public:
        void addVertex(int vertex);
        void display();
        TCSGraph(){

            head = NULL;
        }
        ~TCSGraph();

    private:
        struct ListNode
        {
            string name;
            struct ListNode *next;
        };

        ListNode *head;
}

void TCSGraph::addVertex(int vertex){
    ListNode *newNode;
    ListNode *nodePtr;
    string vName;

    for(int i = 0; i < vertex ; i++ ){
        cout << "what is the name of the vertex"<< endl;
        cin >> vName;
        newNode = new ListNode;
        newNode->name = vName;

        if (!head)
        head = newNode;
        else
        nodePtr = head;
        while(nodePtr->next)
        nodePtr = nodePtr->next;

        nodePtr->next = newNode;

    }
}

void TCSGraph::display(){
    ListNode *nodePtr;
    nodePtr = head;

    while(nodePtr){
    cout << nodePtr->name<< endl;
    nodePtr = nodePtr->next;
    }
}

int main(){
int vertex;

cout << " how many vertex u wan to add" << endl;
cin >> vertex;

TCSGraph g;
g.addVertex(vertex);
g.display();

return 0;
}

Ответы [ 2 ]

2 голосов
/ 20 апреля 2010

В вас есть проблема addvertex метод:

У вас есть:

if (!head) 
    head = newNode; 
else
nodePtr = head;
while(nodePtr->next)
nodePtr = nodePtr->next;
nodePtr->next = newNode;

но оно должно быть:

if (!head) // check if the list is empty.
    head = newNode;// if yes..make the new node the first node.
else { // list exits.
    nodePtr = head;
    while(nodePtr->next) // keep moving till the end of the list.
        nodePtr = nodePtr->next;
    nodePtr->next = newNode; // add new node to the end.
}

Также вы не являетесьсоздание поля next для newNode NULL:

newNode = new ListNode;
newNode->name = vName;
newNode->next= NULL; // add this.

Хорошей практикой также является освобождение динамически выделяемой памяти.Поэтому вместо пустого деструктора

~TCSGraph();

вы можете освободить список в dtor.

РЕДАКТИРОВАТЬ: больше ошибок

У вас естьпропавший без вести;после объявления класса:

class TCSGraph{
......

}; // <--- add this ;

Также ваш деструктор только объявлен.Там нет определения.Если вы не хотите давать никакой защиты, у вас должно быть хотя бы пустое тело.Поэтому замените

~TCSGraph();

на

~TCSGraph(){}
0 голосов
/ 20 апреля 2010

Взглянули ли вы на Boost Graph Library и boost::adjacency_list?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...