Kindly answer the following C programming question based on the following code! #include #include #define MAX_VERTEX_NUM 20 //MAX number of vertices typedef struct edgenode { char vertex; int weight; struct edgenode *nextEdge; } EdgeNode, *EdgeNodePtr; typedef struct vertexnode { char vertex; EdgeNodePtr firstEdge; } VertexNode, *VertexNodePtr; typedef struct { int size; char vertices[MAX_VERTEX_NUM]; VertexNode AdjList[MAX_VERTEX_NUM]; } AdjListGraph, *Graph; //Create a graph of n vertices, use dynamic memory //- given the vertices and the size, return the graph Graph createGraph(char vertices[], int size) { Graph graph = (Graph)malloc(sizeof(AdjListGraph)); graph->size = size; for (int i = 0; i < size; i++) { graph->vertices[i] = vertices[i]; graph->AdjList[i].vertex = vertices[i]; graph->AdjList[i].firstEdge = NULL; } return graph; } //Print the graph as an adjacency matrix void printGraph(Graph graph) { if (graph == NULL) { puts("Graph is empty"); return; } for (int i = 0; i < graph->size; i++) { printf("|%c|->", graph->vertices[i]); EdgeNodePtr curr = graph->AdjList[i].firstEdge; while(curr != NULL) { printf("|%c|%d|->", curr->vertex, curr->weight); curr = curr->nextEdge; } puts("NULL"); } } //Delete the graph, i.e. free the memory Graph deleteGraph(Graph graph) { if (graph == NULL) { puts("Graph is empty"); return NULL; } for (int i = 0; i < graph->size; i++) { EdgeNodePtr pre = NULL; EdgeNodePtr curr = graph->AdjList[i].firstEdge; while(curr != NULL) { pre = curr; curr = curr->nextEdge; free(pre); } } free(graph); return NULL; } //Do NOT MODIFY ANY CODE ABOVE THIS LINE -------------------------------------- void addEdge(Graph graph, int u, int v, int w) { //TODO } //Do NOT MODIFY ANY CODE BELOW THIS LINE -------------------------------------- int main() { //Create the graph with 5 vertices char vertices[MAX_VERTEX_NUM]; for (int i = 0; i < MAX_VERTEX_NUM; i++) vertices[i] = 'A' + i; Graph g1 = createGraph(vertices, 5); //Add edges int edges[] = {0,1,3, 1,2,2, 1,3,4, 2,4,5, 3,2,5, 4,3,2}; for (int i = 0; i < (int)(sizeof(edges)/sizeof(int)); i += 3) addEdge(g1, edges[i], edges[i+1], edges[i+2]); printGraph(g1); //Delete the graph g1 = deleteGraph(g1); } //end of main
Kindly answer the following C programming question based on the following code!
#include <stdio.h>
#include <stdlib.h>
#define MAX_VERTEX_NUM 20 //MAX number of vertices
typedef struct edgenode {
char vertex;
int weight;
struct edgenode *nextEdge;
} EdgeNode, *EdgeNodePtr;
typedef struct vertexnode {
char vertex;
EdgeNodePtr firstEdge;
} VertexNode, *VertexNodePtr;
typedef struct {
int size;
char vertices[MAX_VERTEX_NUM];
VertexNode AdjList[MAX_VERTEX_NUM];
} AdjListGraph, *Graph;
//Create a graph of n vertices, use dynamic memory
//- given the vertices and the size, return the graph
Graph createGraph(char vertices[], int size) {
Graph graph = (Graph)malloc(sizeof(AdjListGraph));
graph->size = size;
for (int i = 0; i < size; i++) {
graph->vertices[i] = vertices[i];
graph->AdjList[i].vertex = vertices[i];
graph->AdjList[i].firstEdge = NULL;
}
return graph;
}
//Print the graph as an adjacency matrix
void printGraph(Graph graph) {
if (graph == NULL) {
puts("Graph is empty");
return;
}
for (int i = 0; i < graph->size; i++) {
printf("|%c|->", graph->vertices[i]);
EdgeNodePtr curr = graph->AdjList[i].firstEdge;
while(curr != NULL) {
printf("|%c|%d|->", curr->vertex, curr->weight);
curr = curr->nextEdge;
}
puts("NULL");
}
}
//Delete the graph, i.e. free the memory
Graph deleteGraph(Graph graph) {
if (graph == NULL) {
puts("Graph is empty");
return NULL;
}
for (int i = 0; i < graph->size; i++) {
EdgeNodePtr pre = NULL;
EdgeNodePtr curr = graph->AdjList[i].firstEdge;
while(curr != NULL) {
pre = curr;
curr = curr->nextEdge;
free(pre);
}
}
free(graph);
return NULL;
}
//Do NOT MODIFY ANY CODE ABOVE THIS LINE --------------------------------------
void addEdge(Graph graph, int u, int v, int w) {
//TODO
}
//Do NOT MODIFY ANY CODE BELOW THIS LINE --------------------------------------
int main() {
//Create the graph with 5 vertices
char vertices[MAX_VERTEX_NUM];
for (int i = 0; i < MAX_VERTEX_NUM; i++)
vertices[i] = 'A' + i;
Graph g1 = createGraph(vertices, 5);
//Add edges
int edges[] = {0,1,3, 1,2,2, 1,3,4, 2,4,5, 3,2,5, 4,3,2};
for (int i = 0; i < (int)(sizeof(edges)/sizeof(int)); i += 3)
addEdge(g1, edges[i], edges[i+1], edges[i+2]);
printGraph(g1);
//Delete the graph
g1 = deleteGraph(g1);
} //end of main
data:image/s3,"s3://crabby-images/9d28f/9d28fa611fad2aabf33b15b72ee60adb27f0caf7" alt="●
Write a function addEdge, based on provided code.
o
The function adds a new edge from u to v of weight w to the graph.
Suppose this is a directed graph, so only add (u, v), not (v, u)
o
o New edge node to be in heap and to be inserted to the end of the list
Use the provided function headers in the starter file. Finish the TODOS.
See below an example screenshot and the expected output.
NOTE: for this assignment you don't need to submit anything as you will write it in Quiz 4.
Online C Compiler - online editor x X
> C
19
onlinegdb.com/online c compiler
SPONSOR Mailchimp - Create stunning brand assets with the help of our Al-driven Creative Assistant. Get started today.
A ▶ Run Ⓒ Debug Stop Share Save Beautify +
main.c
10
113
71 //DO NOT MODIFY ANY CODE ABOVE THIS LINE
77
73./4
74 Assignment 4.4: Graph Representation
D'
- Read the provided code. Do NOT modify any of them.
76
Write a function addEdge, bused on provided code.
77
78
-
The function add a new edge from u to v of weight w to the graph
- Suppose this is a directed graph, so only add (u, v), not (v, u)
New edge node to be in heap and to be inserted to the end of the list
You must use the provided function headers below.
+
79
80
81 7/
82 void addEdge (Graph graph, int u, int v, int w) {
///(XX)
883
✔✔
-
|A|->|B|3|->NULL
|B|->|C|2|->|D|4|->NULL
|C|->|E|5|->NULL
|D|->|C|5|->NULL
E|-|D|2|->NULL
...Program finished with exil code 0
Press ENTER to exil console.
input
Language C
0
J ⠀"
data:image/s3,"s3://crabby-images/00039/00039eaf710a9765f6db01fc5b9812260bf5cade" alt=""
Step by step
Solved in 4 steps with 3 images
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"