-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathgraph.h
33 lines (29 loc) · 1.12 KB
/
graph.h
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
#ifndef _GRAPH_H_
#define _GRAPH_H_
#include <stdlib.h>
#include "../list/list.h"
#include "../set/set.h"
typedef struct _AdjList_ {
void *vertex;
Set adjacent;
} AdjList;
typedef struct _Graph_ {
int vcount;
int ecount;
int (*match)(const void *key1, const void *key2);
void (*destory)(void *data);
List adjlists;
} Graph;
typedef enum _VertexColor_ {white, gray, black} VertexColor;
void graph_init(Graph *graph, int (*match)(const void *key1, const void *key2), void (*destory)(void *data));
void graph_destory(Graph *graph);
int graph_insert_vertex(Graph *graph, const void *data);
int graph_insert_edge(Graph *graph, const void *data1, const void *data2);
int graph_remove_vertex(Graph *graph, void **data);
int graph_remove_edge(Graph *graph, void *data1, void **data2);
int graph_adjlist(Graph *graph, const void *data, AdjList **adjlist);
int graph_is_adjacent(const Graph *graph, const void *data1, const void *data2);
#define graph_adjlists(graph)((graph)->adjlists)
#define graph_vcount(graph)((graph)->vcount)
#define graph_ecount(graph)((graph)->ecount)
#endif