C programming fill in the following code #include "graph.h" #include #include /* initialise an empty graph */ /* return pointer to initialised graph */ Graph *init_graph(void) { } /* release memory for graph */ void free_graph(Graph *graph) { } /* initialise a vertex */ /* return pointer to initialised vertex */ Vertex *init_vertex(int id) { } /* release memory for initialised vertex */ void free_vertex(Vertex *vertex) { } /* initialise an edge. */ /* return pointer to initialised edge. */ Edge *init_edge(void) { } /* release memory for initialised edge. */ void free_edge(Edge *edge) { } /* remove all edges from vertex with id from to vertex with id to from graph. */ void remove_edge(Graph *graph, int from, int to) { } /* remove all edges from vertex with specified id. */ void remove_edges(Graph *graph, int id) { } /* output all vertices and edges in graph. */ /* each vertex in the graphs should be printed on a new line */ /* each vertex should be printed in the following format: */ /* vertex_id: edge_to_vertex[weight] edge_to_vertex[weight] ... */ /* for example: */ /* 1: 3[1.00] 5[2.00] */ /* indicating that vertex id 1 has edges to vertices 3 and 5 */ /* with weights 1.00 and 2.00 respectively */ /* weights should be output to two decimal places */ void print_graph(Graph *graph) { } /* find vertex with specified id in graph. */ /* return pointer to vertex, or NULL if no vertex found. */ Vertex *find_vertex(Graph *graph, int id) { } /* create and add vertex with specified id to graph. */ /* return pointer to vertex or NULL if an error occurs. */ /* if vertex with id already exists, return pointer to existing vertex. */ Vertex *add_vertex(Graph *graph, int id) { } /* remove vertex with specified id from graph. */ /* remove all edges between specified vertex and any other vertices in graph. */ void remove_vertex(Graph *graph, int id) { } /* add directed edge with specified weight between vertex with id from */ /* to vertex with id to. */ /* if no vertices with specified ids (from or to) exist */ /* then the vertices will be created. */ /* multiple edges between the same pair of vertices are allowed. */ /* return pointer to edge, or NULL if an error occurs found. */ Edge *add_edge(Graph *graph, int from, int to, double weight) { } /* add two edges to graph, one from vertex with id from to vertex with id to, */ /* and one from vertex with id to to vertex with id from. */ /* both edges should have the same weight */ /* if no vertices with specified ids (from or to) exist */ /* then the vertices will be created. */ /* multiple vertices between the same pair of vertices are allowed. */ void add_edge_undirected(Graph *graph, int from, int to, double weight) { } /* return array of node ids in graph. */ /* array of node ids should be dynamically allocated */ /* set count to be the number of nodes in graph */ /* return NULL if no vertices in graph */ int *get_vertices(Graph *graph, int *count) { } /* return array of pointers to edges for a given vertex. */ /* array of edges should be dynamically allocated */ /* set count to be number of edges of vertex */ /* return NULL if no edges from/to vertex */ Edge **get_edges(Graph *graph, Vertex *vertex, int *count) { } /* return pointer to edge from vertex with id from, to vertex with id to. */ /* return NULL if no edge */ Edge *get_edge(Graph *graph, int from, int to) { } /* return id of destination node of edge. */ int edge_destination(Edge *edge) { } /* return weight of edge. */ double edge_weight(Edge *edge) { }
C programming
fill in the following code
#include "graph.h"
#include <stdio.h>
#include <stdlib.h>
/* initialise an empty graph */
/* return pointer to initialised graph */
Graph *init_graph(void)
{
}
/* release memory for graph */
void free_graph(Graph *graph)
{
}
/* initialise a vertex */
/* return pointer to initialised vertex */
Vertex *init_vertex(int id)
{
}
/* release memory for initialised vertex */
void free_vertex(Vertex *vertex)
{
}
/* initialise an edge. */
/* return pointer to initialised edge. */
Edge *init_edge(void)
{
}
/* release memory for initialised edge. */
void free_edge(Edge *edge)
{
}
/* remove all edges from vertex with id from to vertex with id to from graph. */
void remove_edge(Graph *graph, int from, int to)
{
}
/* remove all edges from vertex with specified id. */
void remove_edges(Graph *graph, int id)
{
}
/* output all vertices and edges in graph. */
/* each vertex in the graphs should be printed on a new line */
/* each vertex should be printed in the following format: */
/* vertex_id: edge_to_vertex[weight] edge_to_vertex[weight] ... */
/* for example: */
/* 1: 3[1.00] 5[2.00] */
/* indicating that vertex id 1 has edges to vertices 3 and 5 */
/* with weights 1.00 and 2.00 respectively */
/* weights should be output to two decimal places */
void print_graph(Graph *graph)
{
}
/* find vertex with specified id in graph. */
/* return pointer to vertex, or NULL if no vertex found. */
Vertex *find_vertex(Graph *graph, int id)
{
}
/* create and add vertex with specified id to graph. */
/* return pointer to vertex or NULL if an error occurs. */
/* if vertex with id already exists, return pointer to existing vertex. */
Vertex *add_vertex(Graph *graph, int id)
{
}
/* remove vertex with specified id from graph. */
/* remove all edges between specified vertex and any other vertices in graph. */
void remove_vertex(Graph *graph, int id)
{
}
/* add directed edge with specified weight between vertex with id from */
/* to vertex with id to. */
/* if no vertices with specified ids (from or to) exist */
/* then the vertices will be created. */
/* multiple edges between the same pair of vertices are allowed. */
/* return pointer to edge, or NULL if an error occurs found. */
Edge *add_edge(Graph *graph, int from, int to, double weight)
{
}
/* add two edges to graph, one from vertex with id from to vertex with id to, */
/* and one from vertex with id to to vertex with id from. */
/* both edges should have the same weight */
/* if no vertices with specified ids (from or to) exist */
/* then the vertices will be created. */
/* multiple vertices between the same pair of vertices are allowed. */
void add_edge_undirected(Graph *graph, int from, int to, double weight)
{
}
/* return array of node ids in graph. */
/* array of node ids should be dynamically allocated */
/* set count to be the number of nodes in graph */
/* return NULL if no vertices in graph */
int *get_vertices(Graph *graph, int *count)
{
}
/* return array of pointers to edges for a given vertex. */
/* array of edges should be dynamically allocated */
/* set count to be number of edges of vertex */
/* return NULL if no edges from/to vertex */
Edge **get_edges(Graph *graph, Vertex *vertex, int *count)
{
}
/* return pointer to edge from vertex with id from, to vertex with id to. */
/* return NULL if no edge */
Edge *get_edge(Graph *graph, int from, int to)
{
}
/* return id of destination node of edge. */
int edge_destination(Edge *edge)
{
}
/* return weight of edge. */
double edge_weight(Edge *edge)
{
}
data:image/s3,"s3://crabby-images/fce59/fce59fb205dc444a8c2b5ab177f68b164fd3ec95" alt="h graph.h 1.16 KB
1 #ifndef _GRAPH_H
2 #define _GRAPH_H
3
4 #include "linked_list.h"
5
6
7
8
10
11
12
13
14
A
15
16
17
18
19
20
21
22
23
24
25
26
27
35
36
37
20
38
So
39
10
40
/* a graph represented as an adjacency List */
typedef LinkedList Graph;
41
42
43
44
/* each node in the adjacency List stores a vertex */
/* a vertex has a unique numerical id */
/* and stores a List of edges from the vertex */
typedef struct Vertex {
47
48
10
49
int id;
LinkedList sedges;
> Vertex;
Graph *init_graph(void);
void free_graph(Graph *);
28 void print_graph(Graph *);
/* each node in the list of edges for a vertex store the edge weight */
/* and the destination vertex */
typedef struct Edge {
29 Vertex *find_vertex (Graph *, int);
30
Vertex *add_vertex (Graph *, int);
31
void remove_vertex (Graph *, int);
32 Edge *add_edge (Graph *, int, int, double);
33 void add_edge_undirected (Graph *, int, int, double);
34 void remove_edge (Graph *, int, int);
void remove_edges (Graph *, int);
double weight;
Vertex *vertex;
} Edge;
/* function prototypes /
Vertex *init_vertex(int);
void free_vertex (Vertex *);
Edge *init_edge (void);
void free edge (Edge *);
int *get_vertices (Graph *, int *);
Edge **get_edges (Graph *, Vertex *, int *);
Edge *get_edge (Graph *, int, int);
45
46 int edge destination (Edge *);
double edge_weight (Edge *);
#endif
Open in Web IDE
Replace
Delete"
data:image/s3,"s3://crabby-images/00039/00039eaf710a9765f6db01fc5b9812260bf5cade" alt=""
Step by step
Solved in 3 steps
data:image/s3,"s3://crabby-images/e0cbe/e0cbe7c1cfa79a285a06530332b315bcf077d9a4" alt="Blurred answer"
data:image/s3,"s3://crabby-images/60092/600925f3c879aa48326d2697cc12cbd501c16012" alt="Database System Concepts"
data:image/s3,"s3://crabby-images/b5b1d/b5b1d5cf4b4f0b9fa5f7299e517dda8c78973ae2" alt="Starting Out with Python (4th Edition)"
data:image/s3,"s3://crabby-images/861e9/861e9f01dc31d6a60742dd6c59ed7da7e28cd75d" alt="Digital Fundamentals (11th Edition)"
data:image/s3,"s3://crabby-images/60092/600925f3c879aa48326d2697cc12cbd501c16012" alt="Database System Concepts"
data:image/s3,"s3://crabby-images/b5b1d/b5b1d5cf4b4f0b9fa5f7299e517dda8c78973ae2" alt="Starting Out with Python (4th Edition)"
data:image/s3,"s3://crabby-images/861e9/861e9f01dc31d6a60742dd6c59ed7da7e28cd75d" alt="Digital Fundamentals (11th Edition)"
data:image/s3,"s3://crabby-images/134f1/134f1b748b071d72903e45f776c363a56b72169f" alt="C How to Program (8th Edition)"
data:image/s3,"s3://crabby-images/3a774/3a774d976e0979e81f9a09e78124a494a1b36d93" alt="Database Systems: Design, Implementation, & Manag…"
data:image/s3,"s3://crabby-images/307b2/307b272f255471d7f7dc31378bac8a580ae1c49c" alt="Programmable Logic Controllers"