5 what is graph ? explain adjacent matrix and adjacent list for graph.
Ans:
a graph is a fundamental data structure used to model relationships between objects. Let’s understand this
step-by-step:
🔷 What is a Graph?
A graph is a collection of:
   •   Vertices (or nodes): Represent entities.
   •   Edges (or arcs): Represent connections (relationships) between those entities.
A graph can be:
   •   Directed: Edges have direction (e.g., one-way roads).
   •   Undirected: Edges are bidirectional (e.g., mutual friendships).
A graph can also be:
   •   Weighted: Edges carry a weight or cost.
   •   Unweighted: Edges don’t carry any cost.
🔷 Types of Graph Representation
There are two common ways to represent graphs in memory:
✅ 1. Adjacency Matrix
An Adjacency Matrix is a 2D array of size V x V where V is the number of vertices in the graph.
   •   adj[i][j] = 1: There is an edge from vertex i to vertex j.
   •   adj[i][j] = 0: There is no edge from i to j.
For weighted graphs, we store the weight instead of 1.
🔹 Example:
Graph with 3 vertices and edges: (0→1), (1→2)
Adjacency Matrix:
  012
 -------
0|010
1|001
2|000
🔹 Characteristics:
   •   Space: O(V²) (even if the graph is sparse)
   •   Quick lookup to check if an edge exists
   •   Not efficient for sparse graphs
✅ 2. Adjacency List
An Adjacency List is an array of lists. The index represents the node, and each element in its list represents
the connected nodes.
🔹 Example:
Graph with edges: (0→1), (1→2)
Adjacency List:
0→1
1→2
2→∅
List[0] = [1]
List[1] = [2]
List[2] = []
🔹 Characteristics:
   •   Space: O(V + E) (efficient for sparse graphs)
   •   Slower to check if an edge exists (linear in list size)
   •   Efficient for iterating over neighbors
6. explain following terms direct graph , undirect graph , mix graph , complete graph , weight graph
, null graph , a cyclic graph , cycle , loop , isolated vertex , adjacent vertex , degree of the graph , leaf
vertex
Ans:
🔷 1. Directed Graph (Digraph)
A graph in which edges have direction.
   •   Each edge is an ordered pair (u, v) meaning from u → v.
   •   Used in one-way systems, like roads or workflows.
🧠 Example: A → B, B → C
🔷 2. Undirected Graph
A graph where edges have no direction.
    •   Edge (u, v) is the same as (v, u).
    •   Used in mutual relationships like friendship networks.
🧠 Example: A — B, B — C
🔷 3. Mixed Graph
A graph that has both directed and undirected edges.
    •   Some edges are one-way, and others are two-way.
    •   Useful in traffic maps where some roads are one-way.
🧠 Example: A → B, B — C
🔷 4. Complete Graph
A graph in which every pair of vertices is connected by a unique edge.
    •   For n vertices, it has n(n−1)/2 edges in undirected graphs.
🧠 Example:
For 3 vertices:
A—B
| /
C
🔷 5. Weighted Graph
A graph where edges carry weights or costs.
    •   Used to represent distances, costs, or capacities.
    •   Common in shortest path problems (Dijkstra’s Algorithm).
🧠 Example:
A —(5)— B
🔷 6. Null Graph
A graph with no edges, only isolated vertices.
    •   It’s the most minimal graph possible.
🧠 Example:
Vertices: A, B, C, D
Edges: None
🔷 7. Acyclic Graph
A graph that has no cycles.
   •   In Directed Graphs, it’s called a Directed Acyclic Graph (DAG).
   •   Common in task scheduling, dependency resolution.
🧠 Example:
A → B → C (no loop back to A)
🔷 8. Cycle
A closed path in a graph where the starting and ending vertex is the same and no other vertex repeats.
   •   Must have at least 3 vertices in undirected graphs.
   •   In directed graphs: all edges must follow direction.
🧠 Example:
A→B→C→A
🔷 9. Loop
An edge that starts and ends at the same vertex.
🧠 Example:
A → A or A — A
🔷 10. Isolated Vertex
A vertex that has no incident edges (i.e., no connections).
🧠 Example:
In a graph with vertices {A, B, C}, if only A and B are connected, C is isolated.
🔷 11. Adjacent Vertex
Two vertices are adjacent if there is an edge between them.
🧠 Example:
If A — B exists, then A and B are adjacent.
🔷 12. Degree of a Graph (Vertex Degree)
The number of edges connected to a vertex.
    •   In undirected graphs:
            o Degree = number of connected edges.
    •   In directed graphs:
            o In-degree: Edges coming into the vertex.
            o Out-degree: Edges going out from the vertex.
🧠 Example:
If A → B and C → A, then:
    •   A: In-degree = 1, Out-degree = 1
    •   Degree (undirected) of B in A — B = 1
🔷 13. Leaf Vertex (Pendant Vertex)
A vertex with degree 1 — connected by only one edge.
🧠 Example:
If A is connected only to B, then A is a leaf.
7. explain graph travasal with example.
Ans:
✅ Graph Traversal in Advanced Algorithm (with C code)
Graph traversal means visiting all the vertices of a graph in a systematic way. There are two primary
traversal techniques:
🔷 1. Breadth-First Search (BFS)
    •   Visits neighbors level by level.
    •   Uses a queue.
    •   Ideal for finding the shortest path in unweighted graphs.
🧠 Example Graph:
0—1—2
|       |
3 ———— 4
Adjacency list:
0 → 1, 3
1 → 0, 2
2 → 1, 4
3 → 0, 4
4 → 2, 3
Code for BFS:
#include <stdio.h>
#include <stdlib.h>
#define SIZE 100
int visited[SIZE] = {0};
int queue[SIZE], front = -1, rear = -1;
void enqueue(int value) {
    if (rear == SIZE - 1) return;
    if (front == -1) front = 0;
    queue[++rear] = value;
int dequeue() {
    if (front == -1 || front > rear) return -1;
    return queue[front++];
void bfs(int graph[][SIZE], int n, int start) {
    enqueue(start);
    visited[start] = 1;
    while (front <= rear) {
      int vertex = dequeue();
      prin\("%d ", vertex);
      for (int i = 0; i < n; i++) {
         if (graph[vertex][i] == 1 && !visited[i]) {
           enqueue(i);
            visited[i] = 1;
         }}}}
🔷 2. Depth-First Search (DFS)
   •     Visits nodes deep before wide.
   •     Uses recursion or a stack.
   •     Suitable for cycle detection, topological sort, etc.
✅ C Code for DFS (using recursion):
#include <stdio.h>
#define SIZE 100
int visited[SIZE] = {0};
void dfs(int graph[][SIZE], int n, int vertex) {
  visited[vertex] = 1;
  prin\("%d ", vertex);
  for (int i = 0; i < n; i++) {
       if (graph[vertex][i] == 1 && !visited[i]) {
         dfs(graph, n, i);
       } } }
🔷 Sample Main Function (for both BFS & DFS)
int main() {
  int graph[SIZE][SIZE] = {
       {0, 1, 0, 1, 0},
       {1, 0, 1, 0, 0},
       {0, 1, 0, 0, 1},
       {1, 0, 0, 0, 1},
       {0, 0, 1, 1, 0}
  };
  int n = 5;
    prin\("BFS stardng from vertex 0:\n");
    bfs(graph, n, 0);
    // Reset visited array for DFS
    for (int i = 0; i < SIZE; i++) visited[i] = 0;
    prin\("\nDFS stardng from vertex 0:\n");
    dfs(graph, n, 0);
    return 0;
Output:
BFS stardng from vertex 0:
01324
DFS stardng from vertex 0:
01243
8. write an algorithm for DFS and BFS. (graph travasal method ) .
Ans:
Here are the algorithms and corresponding C-language implementations for DFS and BFS, commonly
used in Advanced Algorithm graph traversal.
🔷 1. Algorithm for Depth-First Search (DFS)
📘 Algorithm (Recursive DFS)
DFS(G, v):
1. Mark v as visited
2. Process v (e.g., print v)
3. For each neighbor u of v in G:
    If u is not visited:
       Call DFS(G, u)
✅ C Program for DFS using Adjacency Matrix
#include <stdio.h>
#define SIZE 100
int visited[SIZE];
void DFS(int graph[][SIZE], int n, int v) {
    visited[v] = 1;
    prin\("%d ", v);
    for (int i = 0; i < n; i++) {
         if (graph[v][i] == 1 && !visited[i]) {
             DFS(graph, n, i);
         }
    }
int main() {
    int n = 5;
    int graph[SIZE][SIZE] = {
         {0, 1, 0, 1, 0},
         {1, 0, 1, 0, 0},
         {0, 1, 0, 0, 1},
         {1, 0, 0, 0, 1},
         {0, 0, 1, 1, 0}
    };
    for (int i = 0; i < SIZE; i++) visited[i] = 0;
    prin\("DFS stardng from vertex 0:\n");
    DFS(graph, n, 0);
    return 0; }
🔷 2. Algorithm for Breadth-First Search (BFS)
📘 Algorithm (BFS using Queue)
BFS(G, start):
1. Inidalize a queue Q
2. Mark start as visited and enqueue it into Q
3. While Q is not empty:
    a. Dequeue a vertex v from Q
    b. Process v (e.g., print v)
    c. For each neighbor u of v in G:
       If u is not visited:
          Mark u as visited
          Enqueue u into Q
✅ C Program for BFS using Adjacency Matrix
#include <stdio.h>
#define SIZE 100
int visited[SIZE];
int queue[SIZE], front = -1, rear = -1;
void enqueue(int value) {
    if (rear == SIZE - 1) return;
    if (front == -1) front = 0;
    queue[++rear] = value;
int dequeue() {
    if (front == -1 || front > rear) return -1;
    return queue[front++];
}
void BFS(int graph[][SIZE], int n, int start) {
    enqueue(start);
    visited[start] = 1;
    while (front <= rear) {
         int v = dequeue();
         prin\("%d ", v);
         for (int i = 0; i < n; i++) {
           if (graph[v][i] == 1 && !visited[i]) {
              enqueue(i);
              visited[i] = 1;
           }}}}
int main() {
    int n = 5;
    int graph[SIZE][SIZE] = {
         {0, 1, 0, 1, 0},
         {1, 0, 1, 0, 0},
         {0, 1, 0, 0, 1},
         {1, 0, 0, 0, 1},
         {0, 0, 1, 1, 0}
    };
    for (int i = 0; i < SIZE; i++) visited[i] = 0;
    prin\("BFS stardng from vertex 0:\n");
    BFS(graph, n, 0);
    return 0;