 
- Discrete Mathematics - Home
- Discrete Mathematics Introduction
- Mathematical Statements and Operations
- Atomic and Molecular Statements
- Implications
- Predicates and Quantifiers
- Sets
- Sets and Notations
- Relations
- Operations on Sets
- Venn Diagrams on Sets
- Functions
- Surjection and Bijection Functions
- Image and Inverse-Image
- Mathematical Logic
- Propositional Logic
- Logical Equivalence
- Deductions
- Predicate Logic
- Proof by Contrapositive
- Proof by Contradiction
- Proof by Cases
- Rules of Inference
- Group Theory
- Operators & Postulates
- Group Theory
- Algebric Structure for Groups
- Abelian Group
- Semi Group
- Monoid
- Rings and Subring
- Properties of Rings
- Integral Domain
- Fields
- Counting & Probability
- Counting Theory
- Combinatorics
- Additive and Multiplicative Principles
- Counting with Sets
- Inclusion and Exclusion
- Bit Strings
- Lattice Path
- Binomial Coefficients
- Pascal's Triangle
- Permutations and Combinations
- Pigeonhole Principle
- Probability Theory
- Probability
- Sample Space, Outcomes, Events
- Conditional Probability and Independence
- Random Variables in Probability Theory
- Distribution Functions in Probability Theory
- Variance and Standard Deviation
- Mathematical & Recurrence
- Mathematical Induction
- Formalizing Proofs for Mathematical Induction
- Strong and Weak Induction
- Recurrence Relation
- Linear Recurrence Relations
- Non-Homogeneous Recurrence Relations
- Solving Recurrence Relations
- Master's Theorem
- Generating Functions
- Graph Theory
- Graph & Graph Models
- More on Graphs
- Planar Graphs
- Non-Planar Graphs
- Polyhedra
- Introduction to Trees
- Properties of Trees
- Rooted and Unrooted Trees
- Spanning Trees
- Graph Coloring
- Coloring Theory in General
- Coloring Edges
- Euler Paths and Circuits
- Hamiltonion Path
- Boolean Algebra
- Boolean Expressions & Functions
- Simplification of Boolean Functions
- Advanced Topics
- Number Theory
- Divisibility
- Remainder Classes
- Properties of Congruence
- Solving Linear Diophantine Equation
- Useful Resources
- Quick Guide
- Useful Resources
- Discussion
Discrete Mathematics - More On Graphs
Graph Coloring
Graph coloring is the procedure of assignment of colors to each vertex of a graph G such that no adjacent vertices get same color. The objective is to minimize the number of colors while coloring a graph. The smallest number of colors required to color a graph G is called its chromatic number of that graph. Graph coloring problem is a NP Complete problem.
Method to Color a Graph
The steps required to color a graph G with n number of vertices are as follows −
Step 1 − Arrange the vertices of the graph in some order.
Step 2 − Choose the first vertex and color it with the first color.
Step 3 − Choose the next vertex and color it with the lowest numbered color that has not been colored on any vertices adjacent to it. If all the adjacent vertices are colored with this color, assign a new color to it. Repeat this step until all the vertices are colored.
Example
 
In the above figure, at first vertex $a$ is colored red. As the adjacent vertices of vertex a are again adjacent, vertex $b$ and vertex $d$ are colored with different color, green and blue respectively. Then vertex $c$ is colored as red as no adjacent vertex of $c$ is colored red. Hence, we could color the graph by 3 colors. Hence, the chromatic number of the graph is 3.
Applications of Graph Coloring
Some applications of graph coloring include −
- Register Allocation
- Map Coloring
- Bipartite Graph Checking
- Mobile Radio Frequency Assignment
- Making time table, etc.
Graph Traversal
Graph traversal is the problem of visiting all the vertices of a graph in some systematic order. There are mainly two ways to traverse a graph.
- Breadth First Search
- Depth First Search
Breadth First Search
Breadth First Search (BFS) starts at starting level-0 vertex $X$ of the graph $G$. Then we visit all the vertices that are the neighbors of $X$. After visiting, we mark the vertices as "visited," and place them into level-1. Then we start from the level-1 vertices and apply the same method on every level-1 vertex and so on. The BFS traversal terminates when every vertex of the graph has been visited.
BFS Algorithm
The concept is to visit all the neighbor vertices before visiting other neighbor vertices of neighbor vertices.
- Initialize status of all nodes as Ready. 
- Put source vertex in a queue and change its status to Waiting. 
- 
Repeat the following two steps until queue is empty − - Remove the first vertex from the queue and mark it as Visited. 
- Add to the rear of queue all neighbors of the removed vertex whose status is Ready. Mark their status as Waiting. 
 
Problem
Let us take a graph (Source vertex is a) and apply the BFS algorithm to find out the traversal order.
 
Solution −
- Initialize status of all vertices to Ready. 
- Put a in queue and change its status to Waiting. 
- Remove a from queue, mark it as Visited. 
- Add as neighbors in Ready state b, d and e to end of queue and mark them as Waiting. 
- Remove b from queue, mark it as Visited, put its Ready neighbor c at end of queue and mark c as Waiting. 
- Remove d from queue and mark it as Visited. It has no neighbor in Ready state. 
- Remove e from queue and mark it as Visited. It has no neighbor in Ready state. 
- Remove c from queue and mark it as Visited. It has no neighbor in Ready state. 
- Queue is empty so stop. 
So the traversal order is −
$a \rightarrow b \rightarrow d \rightarrow e \rightarrow c$
The alternate orders of traversal are −
$a \rightarrow b \rightarrow e \rightarrow d \rightarrow c$
Or, $a \rightarrow d \rightarrow b \rightarrow e \rightarrow c$
Or, $a \rightarrow e \rightarrow b \rightarrow d \rightarrow c$
Or, $a \rightarrow b \rightarrow e \rightarrow d \rightarrow c$
Or, $a \rightarrow d \rightarrow e \rightarrow b \rightarrow c$
Application of BFS
- Finding the shortest path
- Minimum spanning tree for un-weighted graph
- GPS navigation system
- Detecting cycles in an undirected graph
- Finding all nodes within one connected component
Complexity Analysis
Let $G(V, E)$ be a graph with $|V|$ number of vertices and $|E|$ number of edges. If breadth first search algorithm visits every vertex in the graph and checks every edge, then its time complexity would be −
$$O( | V | + | E | ). O( | E | )$$
It may vary between $O(1)$ and $O(|V2|)$
Depth First Search
Depth First Search (DFS) algorithm starts from a vertex $v$, then it traverses to its adjacent vertex (say x) that has not been visited before and mark as "visited" and goes on with the adjacent vertex of $x$ and so on.
If at any vertex, it encounters that all the adjacent vertices are visited, then it backtracks until it finds the first vertex having an adjacent vertex that has not been traversed before. Then, it traverses that vertex, continues with its adjacent vertices until it traverses all visited vertices and has to backtrack again. In this way, it will traverse all the vertices reachable from the initial vertex $v$.
DFS Algorithm
The concept is to visit all the neighbor vertices of a neighbor vertex before visiting the other neighbor vertices.
- Initialize status of all nodes as Ready 
- Put source vertex in a stack and change its status to Waiting 
- 
Repeat the following two steps until stack is empty − - Pop the top vertex from the stack and mark it as Visited 
- Push onto the top of the stack all neighbors of the removed vertex whose status is Ready. Mark their status as Waiting. 
 
Problem
Let us take a graph (Source vertex is a) and apply the DFS algorithm to find out the traversal order.
 
Solution
- Initialize status of all vertices to Ready. 
- Push a in stack and change its status to Waiting. 
- Pop a and mark it as Visited. 
- Push as neighbors in Ready state e, d and b to top of stack and mark them as Waiting. 
- Pop b from stack, mark it as Visited, push its Ready neighbor c onto stack. 
- Pop c from stack and mark it as Visited. It has no Ready neighbor. 
- Pop d from stack and mark it as Visited. It has no Ready neighbor. 
- Pop e from stack and mark it as Visited. It has no Ready neighbor. 
- Stack is empty. So stop. 
So the traversal order is −
$a \rightarrow b \rightarrow c \rightarrow d \rightarrow e$
The alternate orders of traversal are −
$a \rightarrow e \rightarrow b \rightarrow c \rightarrow d$
Or, $a \rightarrow b \rightarrow e \rightarrow c \rightarrow d$
Or, $a \rightarrow d \rightarrow e \rightarrow b \rightarrow c$
Or, $a \rightarrow d \rightarrow c \rightarrow e \rightarrow b$
Or, $a \rightarrow d \rightarrow c \rightarrow b \rightarrow e$
Complexity Analysis
Let $G(V, E)$ be a graph with $|V|$ number of vertices and $|E|$ number of edges. If DFS algorithm visits every vertex in the graph and checks every edge, then the time complexity is −
$$\circleddash ( | V | + | E | )$$
Applications
- Detecting cycle in a graph
- To find topological sorting
- To test if a graph is bipartite
- Finding connected components
- Finding the bridges of a graph
- Finding bi-connectivity in graphs
- Solving the Knights Tour problem
- Solving puzzles with only one solution