1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
|
#include <stdio.h>
#include <stdlib.h>
typedef struct cellule{
int val;
struct cellule *next;
}Cellule;
typedef Cellule *Liste;
typedef struct graphe{
int size;
Liste *adj;
}Graphe;
Cellule *CreerCellule(int val){
Cellule *c = (Cellule*)malloc(sizeof(Cellule));
if(c == NULL)
return NULL;
c->val = val;
c->next = NULL;
return c;
}
Liste consListe(int val, Liste liste)
{
Liste parcours ;
Cellule* c = CreerCellule(val);
if (!c) return NULL ;
if ( liste == NULL )
{
c->next = NULL ;
return c ;
}
for(parcours=liste; parcours->next; parcours=parcours->next ) ;
parcours->next = c ;
return liste;
}
Graphe *consGraph(int size){
int i;
Graphe *g = (Graphe*)malloc(sizeof(Graphe));
if(g == NULL)
return NULL;
g->size = size;
if(size > 0)
g->adj = (Liste*)malloc(size*sizeof(Liste));
else
g->adj = NULL;
for(i=0; i<size; i++)
g->adj[i] = NULL;
return g;
}
void addEdge(Graphe *g, int source, int dest){
g->adj[source] = consListe(dest, g->adj[source]);
}
int main(void)
{
int i ; Liste parcours ;
Graphe *g = NULL;
g = consGraph(3);
addEdge(g,0,1);
addEdge(g,0,2);
addEdge(g,1,2);
for( i=0; i<g->size; i++ )
{
printf( "Sommet %d :", i );
for( parcours=g->adj[i]; parcours; parcours=parcours->next )
printf( " %d", parcours->val ) ;
printf ("\n" ) ;
}
return 0;
} |
Partager