Grafi con liste di adiacenza

di il
1 risposte

Grafi con liste di adiacenza

Salve a tutti avrei dei dubbi sulla questione da cui il titolo.Diciamo che gia so come implementare il grafo fin tanto che i nodi sono numeri per esempio abbiamo un grafo formato da 4 nodi avremo il nodo 0,1,2,3 sono come questi si memorizanoin un vettore di puntatori che inizialmente puntano a null. il mio problema che nn comprendo e che se al posto dei numeri io voglio fare dei nodi con dei nomi primo nodo mario, paolo et...non ci riesco.posto il codice relativo ad un semplice grafo nella struct AdjList dovrei aggiungere il capo per esempio stringe nome quindi poi nel grafo una volta allocata la struttura riempi la parte nome in teoria per mettere i nomi nel vettore ma nn ci riesco qualcuno può aiutarmi. grazie

#include <iostream>
#include <cstdlib>
using namespace std;

/*
* Adjacency List Node
*/
struct AdjListNode
{
int dest;
struct AdjListNode* next;
};

/*
* Adjacency List
*/
struct AdjList
{
struct AdjListNode *head;
};

/*
* Class Graph
*/
class Graph
{
private:
int V;
struct AdjList* array;
public:
Graph(int V)
{
this->V = V;
array = new AdjList [V];
for (int i = 0; i < V; ++i)
array.head = NULL;
}
/*
* Creating New Adjacency List Node
*/
AdjListNode* newAdjListNode(int dest)
{
AdjListNode* newNode = new AdjListNode;
newNode->dest = dest;
newNode->next = NULL;
return newNode;
}
/*
* Adding Edge to Graph
*/
void addEdge(int src, int dest)
{
AdjListNode* newNode = newAdjListNode(dest);
newNode->next = array[src].head;
array[src].head = newNode;
newNode = newAdjListNode(src);
newNode->next = array[dest].head;
array[dest].head = newNode;
}
/*
* Print the graph
*/
void printGraph()
{
int v;
for (v = 0; v < V; ++v)
{
AdjListNode* pCrawl = array[v].head;
cout<<"\n Adjacency list of vertex "<<v<<"\n head ";
while (pCrawl)
{
cout<<"-> "<<pCrawl->dest;
pCrawl = pCrawl->next;
}
cout<<endl;
}
}
};

/*
* Main
*/
int main()
{
Graph gh(5);
gh.addEdge(0, 1);
gh.addEdge(0, 4);
gh.addEdge(1, 2);
gh.addEdge(1, 3);
gh.addEdge(1, 4);
gh.addEdge(2, 3);
gh.addEdge(3, 4);

// print the adjacency list representation of the above graph
gh.printGraph();

return 0;
}
EditReportDelete

1 Risposte

Devi accedere o registrarti per scrivere nel forum
1 risposte