0% found this document useful (0 votes)
33 views81 pages

Ilovepdf Merged

The document provides an overview of set theory, introduced by G. Cantor, defining sets as unordered collections of distinct elements and discussing their representations, types, and operations. It covers concepts such as cardinality, subsets, and various set operations including union, intersection, and Cartesian products. Additionally, it introduces relations between sets and their properties, including domain and range.
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
33 views81 pages

Ilovepdf Merged

The document provides an overview of set theory, introduced by G. Cantor, defining sets as unordered collections of distinct elements and discussing their representations, types, and operations. It covers concepts such as cardinality, subsets, and various set operations including union, intersection, and Cartesian products. Additionally, it introduces relations between sets and their properties, including domain and range.
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 81

Discrete Mathematics - Sets

German mathematician G. Cantor introduced the concept of sets. He had defined a set as a collection
of definite and distinguishable objects selected by the means of certain rules or description.

Set theory forms the basis of several other fields of study like counting theory, relations, graph theory
and finite state machines. In this chapter, we will cover the different aspects of Set Theory.

Set - Definition
A set is an unordered collection of different elements. A set can be written explicitly by listing its
elements using set bracket. If the order of the elements is changed or any element of a set is
repeated, it does not make any changes in the set.

Some Example of Sets

A set of all positive integers

A set of all the planets in the solar system

A set of all the states in India

A set of all the lowercase letters of the alphabet

Representation of a Set
Sets can be represented in two ways −

Roster or Tabular Form


Set Builder Notation

Roster or Tabular Form

The set is represented by listing all the elements comprising it. The elements are enclosed within
braces and separated by commas.

Example 1 − Set of vowels in English alphabet, A = {a, e, i, o, u}

Example 2 − Set of odd numbers less than 10, B = {1, 3, 5, 7, 9}

Set Builder Notation


The set is defined by specifying a property that elements of the set have in common. The set is
described as A = {x : p(x)}

Example 1 − The set {a, e, i, o, u} is written as −

A = {x : x is a vowel in English alphabet}

Example 2 − The set {1, 3, 5, 7, 9} is written as −

B = {x : 1 ≤ x < 10 and (x%2) ≠ 0}

If an element x is a member of any set S, it is denoted by x ∈ S and if an element y is not a member


of set S, it is denoted by y ∉ S.

Example − If S = {1, 1.2, 1.7, 2}, 1 ∈ S but 1.5 ∉ S

Some Important Sets

N − the set of all natural numbers = {1, 2, 3, 4, . . . . . }

Z − the set of all integers = {. . . . . , − 3, − 2, − 1, 0, 1, 2, 3, . . . . . }

Z+ − the set of all positive integers

Q − the set of all rational numbers

R − the set of all real numbers

W − the set of all whole numbers

Explore our latest online courses and learn new skills at your own pace. Enroll and become a certified
expert to boost your career.

Cardinality of a Set
Cardinality of a set S, denoted by | S | , is the number of elements of the set. The number is also
referred as the cardinal number. If a set has an infinite number of elements, its cardinality is ∞.

Example − | {1, 4, 3, 5} | = 4, | {1, 2, 3, 4, 5, …} | = ∞

If there are two sets X and Y,

| X | = | Y | denotes two sets X and Y having same cardinality. It occurs when the number
of elements in X is exactly equal to the number of elements in Y. In this case, there exists a
bijective function ‘f’ from X to Y.
| X | ≤ | Y | denotes that set X’s cardinality is less than or equal to set Y’s cardinality. It
occurs when number of elements in X is less than or equal to that of Y. Here, there exists an
injective function ‘f’ from X to Y.
| X | < | Y | denotes that set X’s cardinality is less than set Y’s cardinality. It occurs when
number of elements in X is less than that of Y. Here, the function ‘f’ from X to Y is injective
function but not bijective.

If | X | ≤ | Y | and | X | ≥ | Y | then | X | = | Y | . The sets X and Y are commonly


referred as equivalent sets.

Types of Sets
Sets can be classified into many types. Some of which are finite, infinite, subset, universal, proper,
singleton set, etc.

Finite Set
A set which contains a definite number of elements is called a finite set.

Example − S = {x | x ∈ N and 70 > x > 50}

Infinite Set
A set which contains infinite number of elements is called an infinite set.

Example − S = {x | x ∈ N and x > 10}

Subset
A set X is a subset of set Y (Written as X ⊆ Y) if every element of X is an element of set Y.

Example 1 − Let, X = {1, 2, 3, 4, 5, 6} and Y = {1, 2}. Here set Y is a subset of set X as all the
elements of set Y is in set X. Hence, we can write Y ⊆ X.

Example 2 − Let, X = {1, 2, 3} and Y = {1, 2, 3}. Here set Y is a subset (Not a proper subset) of
set X as all the elements of set Y is in set X. Hence, we can write Y ⊆ X.

Proper Subset

The term “proper subset” can be defined as “subset of but not equal to”. A Set X is a proper subset of
set Y (Written as X ⊂ Y) if every element of X is an element of set Y and | X | < | Y | .

Example − Let, X = {1, 2, 3, 4, 5, 6} and Y = {1, 2}. Here set Y ⊂ X since all elements in Y are
contained in X too and X has at least one element is more than set Y.

Universal Set
It is a collection of all elements in a particular context or application. All the sets in that context or
application are essentially subsets of this universal set. Universal sets are represented as U.
Example − We may define U as the set of all animals on earth. In this case, set of all mammals is
a subset of U, set of all fishes is a subset of U, set of all insects is a subset of U, and so on.

Empty Set or Null Set


An empty set contains no elements. It is denoted by ∅. As the number of elements in an empty set is
finite, empty set is a finite set. The cardinality of empty set or null set is zero.

Example − S = {x | x ∈ N and 7 < x < 8} = ∅

Singleton Set or Unit Set


Singleton set or unit set contains only one element. A singleton set is denoted by {s}.

Example − S = {x | x ∈ N, 7 < x < 9} = {8}

Equal Set
If two sets contain the same elements they are said to be equal.

Example − If A = {1, 2, 6} and B = {6, 1, 2}, they are equal as every element of set A is an
element of set B and every element of set B is an element of set A.

Equivalent Set
If the cardinalities of two sets are same, they are called equivalent sets.

Example − If A = {1, 2, 6} and B = {16, 17, 22}, they are equivalent as cardinality of A is equal to
the cardinality of B. i.e. | A | = | B | = 3

Overlapping Set
Two sets that have at least one common element are called overlapping sets.

In case of overlapping sets −

n(A ∪ B) = n(A) + n(B) − n(A ∩ B)


n(A ∪ B) = n(A − B) + n(B − A) + n(A ∩ B)

n(A) = n(A − B) + n(A ∩ B)

n(B) = n(B − A) + n(A ∩ B)

Example − Let, A = {1, 2, 6} and B = {6, 12, 42}. There is a common element ‘6’, hence these sets are
overlapping sets.
Disjoint Set
Two sets A and B are called disjoint sets if they do not have even one element in common. Therefore,
disjoint sets have the following properties −

n(A ∩ B) = ∅

n(A ∪ B) = n(A) + n(B)

Example − Let, A = {1, 2, 6} and B = {7, 9, 14}, there is not a single common element, hence these
sets are overlapping sets.

Venn Diagrams
Venn diagram, invented in 1880 by John Venn, is a schematic diagram that shows all possible logical
relations between different mathematical sets.

Examples

Set Operations
Set Operations include Set Union, Set Intersection, Set Difference, Complement of Set, and Cartesian
Product.

Set Union
The union of sets A and B (denoted by A ∪ B) is the set of elements which are in A, in B, or in both A
and B. Hence, A ∪ B = {x | x ∈ A OR x ∈ B}.

Example − If A = {10, 11, 12, 13} and B = {13, 14, 15}, then A ∪ B = {10, 11, 12, 13, 14, 15}. (The
common element occurs only once)
Set Intersection
The intersection of sets A and B (denoted by A ∩ B) is the set of elements which are in both A and B.
Hence, A ∩ B = {x | x ∈ A AND x ∈ B}.

Example − If A = {11, 12, 13} and B = {13, 14, 15}, then A ∩ B = {13}.

Set Difference/ Relative Complement


The set difference of sets A and B (denoted by A– B) is the set of elements which are only in A but not
in B. Hence, A − B = {x | x ∈ A AND x ∉ B}.

Example − If A = {10, 11, 12, 13} and B = {13, 14, 15}, then (A − B) = {10, 11, 12} and
(B − A) = {14, 15}. Here, we can see (A − B) ≠ (B − A)

Complement of a Set

The complement of a set A (denoted by A ′ ) is the set of elements which are not in set A. Hence,
A ′ = {x | x ∉ A}.

More specifically, A ′ = (U − A) where U is a universal set which contains all objects.


Example − If A = {x | x belongs to set of odd integers} then
A ′ = {y | y does not belong to set of odd integers}

Cartesian Product / Cross Product


The Cartesian product of n number of sets A 1, A 2, …A n denoted as A 1 × A 2⋯ × A n can be defined as
all possible ordered pairs (x 1, x 2, …x n) where x 1 ∈ A 1, x 2 ∈ A 2, …x n ∈ A n

Example − If we take two sets A = {a, b} and B = {1, 2},

The Cartesian product of A and B is written as − A × B = {(a, 1), (a, 2), (b, 1), (b, 2)}

The Cartesian product of B and A is written as − B × A = {(1, a), (1, b), (2, a), (2, b)}

Power Set
Power set of a set S is the set of all subsets of S including the empty set. The cardinality of a power
set of a set S of cardinality n is 2 n. Power set is denoted as P(S).

Example −

For a set S = {a, b, c, d} let us calculate the subsets −

Subsets with 0 elements − {∅} (the empty set)

Subsets with 1 element − {a}, {b}, {c}, {d}

Subsets with 2 elements − {a, b}, {a, c}, {a, d}, {b, c}, {b, d}, {c, d}

Subsets with 3 elements − {a, b, c}, {a, b, d}, {a, c, d}, {b, c, d}

Subsets with 4 elements − {a, b, c, d}

Hence, P(S) =

{ {∅}, {a}, {b}, {c}, {d}, {a, b}, {a, c}, {a, d}, {b, c}, {b, d}, {c, d}, {a, b, c}, {a, b, d}, {a, c, d}, {b,

| P(S) | = 2 4 = 16

Note − The power set of an empty set is also an empty set.

| P({∅}) | = 2 0 = 1
Partitioning of a Set
Partition of a set, say S, is a collection of n disjoint subsets, say P 1, P 2, …P n that satisfies the
following three conditions −

P i does not contain the empty set.


[P i ≠ {∅} for all 0 < i ≤ n]

The union of the subsets must equal the entire original set.
[P 1 ∪ P 2 ∪ ⋯ ∪ P n = S]

The intersection of any two distinct sets is empty.


[P a ∩ P b = {∅}, for a ≠ b where n ≥ a, b ≥ 0]

Example

Let S = {a, b, c, d, e, f, g, h}

One probable partitioning is {a}, {b, c, d}, {e, f, g, h}

Another probable partitioning is {a, b}, {c, d}, {e, f, g, h}

Bell Numbers
Bell numbers give the count of the number of ways to partition a set. They are denoted by B n where n
is the cardinality of the set.

Example −

Let S = {1, 2, 3}, n = | S | = 3

The alternate partitions are −

1. ∅, {1, 2, 3}

2. {1}, {2, 3}

3. {1, 2}, {3}

4. {1, 3}, {2}

5. {1}, {2}, {3}

Hence B 3 = 5
Discrete Mathematics - Relations
Whenever sets are being discussed, the relationship between the elements of the sets is the next
thing that comes up. Relations may exist between objects of the same set or between objects of two
or more sets.

Definition and Properties


A binary relation R from set x to y (written as xRy or R(x, y)) is a subset of the Cartesian product x × y.
If the ordered pair of G is reversed, the relation also changes.

Generally an n-ary relation R between sets A 1, …, and A n is a subset of the n-ary product A 1 × ⋯ × A n
. The minimum cardinality of a relation R is Zero and maximum is n 2 in this case.

A binary relation R on a single set A is a subset of A × A.

For two distinct sets, A and B, having cardinalities m and n respectively, the maximum cardinality of a
relation R from A to B is mn.

Domain and Range


If there are two sets A and B, and relation R have order pair (x, y), then −

The domain of R, Dom(R), is the set {x | (x, y) ∈ R for some y in B}

The range of R, Ran(R), is the set {y | (x, y) ∈ R for some x in A}

Examples
Let, A = {1, 2, 9} and B = {1, 3, 7}

Case 1 − If relation R is 'equal to' then R = {(1, 1), (3, 3)}


Dom(R) = {1, 3}, Ran(R) = {1, 3}
Case 2 − If relation R is 'less than' then R = {(1, 3), (1, 7), (2, 3), (2, 7)}
Dom(R) = {1, 2}, Ran(R) = {3, 7}

Case 3 − If relation R is 'greater than' then R = {(2, 1), (9, 1), (9, 3), (9, 7)}
Dom(R) = {2, 9}, Ran(R) = {1, 3, 7}

Explore our latest online courses and learn new skills at your own pace. Enroll and become a certified
expert to boost your career.

Representation of Relations using Graph


A relation can be represented using a directed graph.

The number of vertices in the graph is equal to the number of elements in the set from which the
relation has been defined. For each ordered pair (x, y) in the relation R, there will be a directed edge
from the vertex ‘x’ to vertex ‘y’. If there is an ordered pair (x, x), there will be self- loop on vertex ‘x’.

Suppose, there is a relation R = {(1, 1), (1, 2), (3, 2)} on set S = {1, 2, 3}, it can be represented by the
following graph −

Types of Relations

The Empty Relation between sets X and Y, or on E, is the empty set ∅

The Full Relation between sets X and Y is the set X × Y


The Identity Relation on set X is the set {(x, x) | x ∈ X}

The Inverse Relation R' of a relation R is defined as − R ′ = {(b, a) | (a, b) ∈ R}


Example − If R = {(1, 2), (2, 3)} then R ′ will be {(2, 1), (3, 2)}

A relation R on set A is called Reflexive if ∀a ∈ A is related to a (aRa holds)


Example − The relation R = {(a, a), (b, b)} on set X = {a, b} is reflexive.

A relation R on set A is called Irreflexive if no a ∈ A is related to a (aRa does not hold).


Example − The relation R = {(a, b), (b, a)} on set X = {a, b} is irreflexive.

A relation R on set A is called Symmetric if xRy implies yRx, ∀x ∈ A and ∀y ∈ A.


Example − The relation R = {(1, 2), (2, 1), (3, 2), (2, 3)} on set A = {1, 2, 3} is symmetric.

A relation R on set A is called Anti-Symmetric if xRy and yRx implies x = y ∀x ∈ A and


∀y ∈ A.
Example − The relation R = {(x, y) → N | x ≤ y} is anti-symmetric since x ≤ y and y ≤ x
implies x = y.

A relation R on set A is called Transitive if xRy and yRz implies xRz, ∀x, y, z ∈ A.
Example − The relation R = {(1, 2), (2, 3), (1, 3)} on set A = {1, 2, 3} is transitive.

A relation is an Equivalence Relation if it is reflexive, symmetric, and transitive.


Example − The relation R = {(1, 1), (2, 2), (3, 3), (1, 2), (2, 1), (2, 3), (3, 2), (1, 3), (3, 1)} on set
A = {1, 2, 3} is an equivalence relation since it is reflexive, symmetric, and transitive.
Discrete Mathematics - Functions
A Function assigns to each element of a set, exactly one element of a related set. Functions find their
application in various fields like representation of the computational complexity of algorithms,
counting objects, study of sequences and strings, to name a few. The third and final chapter of this
part highlights the important aspects of functions.

Function - Definition
A function or mapping (Defined as f : X → Y ) is a relationship from elements of one set X to
elements of another set Y (X and Y are non-empty sets). X is called Domain and Y is called Codomain
of function ‘f’.

Function ‘f’ is a relation on X and Y such that for each x ∈ X, there exists a unique y ∈ Y such that
(x, y) ∈ R. ‘x’ is called pre-image and ‘y’ is called image of function f.

A function can be one to one or many to one but not one to many.

Injective / One-to-one function


A function f : A → B is injective or one-to-one function if for every b ∈ B, there exists at most one
a ∈ A such that f(s) = t.

This means a function f is injective if a1 ≠ a2 implies f(a1) ≠ f(a2) .

Example

f : N → N, f(x) = 5x is injective.
f : N → N, f(x) = x2 is injective.
f : R → R, f(x) = x2 is not injective as (−x)2 = x2

Explore our latest online courses and learn new skills at your own pace. Enroll and become a certified
expert to boost your career.

Surjective / Onto function


A function f : A → B is surjective (onto) if the image of f equals its range. Equivalently, for every
b ∈ B, there exists some a ∈ A such that f(a) = b. This means that for any y in B, there exists
some x in A such that y = f(x).

Example
f : N → N, f(x) = x + 2 is surjective.
f : R → R, f(x) = x2 is not surjective since we cannot find a real number whose square
is negative.

Bijective / One-to-one Correspondent


A function f : A → B is bijective or one-to-one correspondent if and only if f is both injective and
surjective.

Problem
Prove that a function f : R → R defined by f(x) = 2x– 3 is a bijective function.

Explanation − We have to prove this function is both injective and surjective.

If f(x1 ) = f(x2 ) , then 2x1 – 3 = 2x2 – 3 and it implies that x1 = x2 .

Hence, f is injective.

Here, 2x– 3 =y

So, x = (y + 5)/3 which belongs to R and f(x) = y.

Hence, f is surjective.

Since f is both surjective and injective, we can say f is bijective.

Inverse of a Function
The inverse of a one-to-one corresponding function f : A → B, is the function g : B → A, holding
the following property −

f(x) = y ⇔ g(y) = x

The function f is called invertible, if its inverse function g exists.

Example

A Function f : Z → Z, f(x) = x + 5 , is invertible since it has the inverse function


g : Z → Z, g(x) = x − 5.
A Function f : Z → Z, f(x) = x2 is not invertiable since this is not one-to-one as
(−x)2 = x2 .

Composition of Functions
Two functions f : A → B and g : B → C can be composed to give a composition gof . This is a
function from A to C defined by (gof)(x) = g(f(x))

Example
Let f(x) = x + 2 and g(x) = 2x + 1, find (fog)(x) and (gof)(x) .

Solution
(fog)(x) = f(g(x)) = f(2x + 1) = 2x
+ 1 + 2 = 2x + 3
(gof)(x) = g(f(x)) = g(x + 2)
= 2(x + 2) + 1 = 2x + 5

Hence, (fog)(x) ≠ (gof)(x)

Some Facts about Composition

If f and g are one-to-one then the function (gof) is also one-to-one.


If f and g are onto then the function (gof) is also onto.

Composition always holds associative property but does not hold commutative property.
Discrete Mathematics - Propositional Logic
The rules of mathematical logic specify methods of reasoning mathematical statements. Greek
philosopher, Aristotle, was the pioneer of logical reasoning. Logical reasoning provides the theoretical
base for many areas of mathematics and consequently computer science. It has many practical
applications in computer science like design of computing machines, artificial intelligence, definition
of data structures for programming languages etc.

Propositional Logic is concerned with statements to which the truth values, “true” and “false”, can be
assigned. The purpose is to analyze these statements either individually or in a composite manner.

Prepositional Logic – Definition


A proposition is a collection of declarative statements that has either a truth value "true” or a truth
value "false". A propositional consists of propositional variables and connectives. We denote the
propositional variables by capital letters (A, B, etc). The connectives connect the propositional
variables.

Some examples of Propositions are given below −

"Man is Mortal", it returns truth value “TRUE”

"12 + 9 = 3 – 2", it returns truth value “FALSE”

The following is not a Proposition −

"A is less than 2". It is because unless we give a specific value of A, we cannot say whether
the statement is true or false.

Connectives
In propositional logic generally we use five connectives which are −

OR (∨)
AND (∧)

Negation/ NOT (¬)


Implication / if-then (→)

If and only if (⇔).


OR (∨) − The OR operation of two propositions A and B (written as A ∨ B ) is true if at least any of
the propositional variable A or B is true.

The truth table is as follows −

A B A∨B

True True True

True False True

False True True

False False False

AND (∧) − The AND operation of two propositions A and B (written as A ∧ B ) is true if both the
propositional variable A and B is true.

The truth table is as follows −

A B A∧B

True True True

True False False

False True False

False False False

Negation (¬) − The negation of a proposition A (written as ¬A) is false when A is true and is true
when A is false.

The truth table is as follows −

A ¬A

True False

False True

Implication / if-then (→) − An implication A → B is the proposition “if A, then B”. It is false if A is
true and B is false. The rest cases are true.

The truth table is as follows −

A B A→B
True True True

True False False

False True True

False False True

If and only if (⇔) − A ⇔ B is bi-conditional logical connective which is true when p and q are same,
i.e. both are false or both are true.

The truth table is as follows −

A B A⇔B

True True True

True False False

False True False

False False True

Explore our latest online courses and learn new skills at your own pace. Enroll and become a certified
expert to boost your career.

Tautologies
A Tautology is a formula which is always true for every value of its propositional variables.

Example − Prove [(A → B) ∧ A] → B is a tautology

The truth table is as follows −

A B A→B (A → B) ∧ A [( A → B ) ∧ A] → B

True True True True True

True False False False True

False True True False True

False False True False True

As we can see every value of [(A → B) ∧ A] → B is "True", it is a tautology.

Contradictions
A Contradiction is a formula which is always false for every value of its propositional variables.

Example − Prove (A ∨ B) ∧ [(¬A) ∧ (¬B)] is a contradiction

The truth table is as follows −

A B A∨B ¬A ¬B (¬ A) ∧ ( ¬ B) (A ∨ B) ∧ [( ¬ A) ∧ (¬ B)]

True True True False False False False

True False True False True False False

False True True True False False False

False False False True True True False

As we can see every value of (A ∨ B) ∧ [(¬A) ∧ (¬B)] is “False”, it is a contradiction.

Contingency
A Contingency is a formula which has both some true and some false values for every value of its
propositional variables.

Example − Prove (A ∨ B) ∧ (¬A) a contingency

The truth table is as follows −

A B A∨B ¬A (A ∨ B) ∧ (¬ A)

True True True False False

True False True False False

False True True True True

False False False True False

As we can see every value of (A ∨ B) ∧ (¬A) has both “True” and “False”, it is a contingency.

Propositional Equivalences
Two statements X and Y are logically equivalent if any of the following two conditions hold −

The truth tables of each statement have the same truth values.

The bi-conditional statement X ⇔ Y is a tautology.


Example − Prove ¬(A ∨ B)and[(¬A) ∧ (¬B)] are equivalent

Testing by 1st method (Matching truth table)

A B A∨B ¬ (A ∨ B) ¬A ¬B [(¬ A) ∧ (¬ B)]

True True True False False False False

True False True False False True False

False True True False True False False

False False False True True True True

Here, we can see the truth values of ¬(A ∨ B)and[(¬A) ∧ (¬B)] are same, hence the statements
are equivalent.

Testing by 2nd method (Bi-conditionality)

A B ¬ (A ∨ B ) [(¬ A) ∧ (¬ B)] [¬ (A ∨ B)] ⇔ [(¬ A ) ∧ (¬ B)]

True True False False True

True False False False True

False True False False True

False False True True True

As [¬(A ∨ B)] ⇔ [(¬A) ∧ (¬B)] is a tautology, the statements are equivalent.

Inverse, Converse, and Contra-positive


Implication / if-then (→) is also called a conditional statement. It has two parts −

Hypothesis, p
Conclusion, q

As mentioned earlier, it is denoted as p → q.

Example of Conditional Statement − “If you do your homework, you will not be punished.” Here, "you
do your homework" is the hypothesis, p, and "you will not be punished" is the conclusion, q.

Inverse − An inverse of the conditional statement is the negation of both the hypothesis and the
conclusion. If the statement is “If p, then q”, the inverse will be “If not p, then not q”. Thus the inverse
of p → q is ¬p → ¬q.

Example − The inverse of “If you do your homework, you will not be punished” is “If you do not do your
homework, you will be punished.”

Converse − The converse of the conditional statement is computed by interchanging the hypothesis
and the conclusion. If the statement is “If p, then q”, the converse will be “If q, then p”. The converse of
p → q is q → p.

Example − The converse of "If you do your homework, you will not be punished" is "If you will not be
punished, you do your homework”.

Contra-positive − The contra-positive of the conditional is computed by interchanging the hypothesis


and the conclusion of the inverse statement. If the statement is “If p, then q”, the contra-positive will
be “If not q, then not p”. The contra-positive of p → q is ¬q → ¬p.

Example − The Contra-positive of " If you do your homework, you will not be punished” is "If you are
punished, you did not do your homework”.

Duality Principle
Duality principle states that for any true statement, the dual statement obtained by interchanging
unions into intersections (and vice versa) and interchanging Universal set into Null set (and vice
versa) is also true. If dual of any statement is the statement itself, it is said self-dual statement.

Example − The dual of (A ∩ B) ∪ C is (A ∪ B) ∩ C

Normal Forms
We can convert any proposition in two normal forms −

Conjunctive normal form

Disjunctive normal form

Conjunctive Normal Form

A compound statement is in conjunctive normal form if it is obtained by operating AND among


variables (negation of variables included) connected with ORs. In terms of set operations, it is a
compound statement obtained by Intersection among variables connected with Unions.

Examples

(A ∨ B) ∧ (A ∨ C) ∧ (B ∨ C ∨ D)
(P ∪ Q) ∩ (Q ∪ R)
Disjunctive Normal Form
A compound statement is in disjunctive normal form if it is obtained by operating OR among variables
(negation of variables included) connected with ANDs. In terms of set operations, it is a compound
statement obtained by Union among variables connected with Intersections.

Examples

(A ∧ B) ∨ (A ∧ C) ∨ (B ∧ C ∧ D)
(P ∩ Q) ∪ (Q ∩ R)
Discrete Mathematics - Predicate Logic
Predicate Logic deals with predicates, which are propositions containing variables.

Predicate Logic – Definition


A predicate is an expression of one or more variables defined on some specific domain. A predicate
with variables can be made a proposition by either assigning a value to the variable or by quantifying
the variable.

The following are some examples of predicates −

Let E(x, y) denote "x = y"

Let X(a, b, c) denote "a + b + c = 0"

Let M(x, y) denote "x is married to y"

Well Formed Formula


Well Formed Formula (wff) is a predicate holding any of the following −

All propositional constants and propositional variables are wffs

If x is a variable and Y is a wff, ∀xY and ∃xY are also wff


Truth value and false values are wffs

Each atomic formula is a wff


All connectives connecting wffs are wffs

Explore our latest online courses and learn new skills at your own pace. Enroll and become a certified
expert to boost your career.

Quantifiers
The variable of predicates is quantified by quantifiers. There are two types of quantifier in predicate
logic − Universal Quantifier and Existential Quantifier.

Universal Quantifier

Universal quantifier states that the statements within its scope are true for every value of the specific
variable. It is denoted by the symbol ∀ .

∀xP (x) is read as for every value of x, P(x) is true.


Example − "Man is mortal" can be transformed into the propositional form ∀xP (x) where P(x) is the
predicate which denotes x is mortal and the universe of discourse is all men.

Existential Quantifier

Existential quantifier states that the statements within its scope are true for some values of the
specific variable. It is denoted by the symbol ∃ .

∃xP (x) is read as for some values of x, P(x) is true.

Example − "Some people are dishonest" can be transformed into the propositional form ∃xP (x)
where P(x) is the predicate which denotes x is dishonest and the universe of discourse is some
people.

Nested Quantifiers

If we use a quantifier that appears within the scope of another quantifier, it is called nested quantifier.

Example

∀ a ∃b P (x, y) where P (a, b) denotes a + b = 0


∀ a ∀ b ∀ c P (a, b, c) where P (a, b) denotes a + (b + c) = (a + b) + c

Note − ∀ a ∃b P (x, y) ≠ ∃a ∀b P (x, y)


Discrete Mathematics - Rules of Inference
To deduce new statements from the statements whose truth that we already know, Rules of Inference
are used.

What are Rules of Inference for?


Mathematical logic is often used for logical proofs. Proofs are valid arguments that determine the
truth values of mathematical statements.

An argument is a sequence of statements. The last statement is the conclusion and all its preceding
statements are called premises (or hypothesis). The symbol “∴”, (read therefore) is placed before the
conclusion. A valid argument is one where the conclusion follows from the truth values of the
premises.

Rules of Inference provide the templates or guidelines for constructing valid arguments from the
statements that we already have.

Table of Rules of Inference

Rule of Inference Name Rule of Inference Name

P P ∨Q
Disjunctive
∴P Addition ¬P
Syllogism
∨Q ∴Q

P P →Q
Q
Conjunction
Q→R Hypothetical
∴P ∴P Syllogism
∧Q →R

(P
→ Q)
∧ (R
P ∧Q Constructive
Simplification → S)
∴P Dilemma
P ∨R
∴Q
∨S
(P
→ Q)
P →Q ∧ (R
Modus → S) Destructive
P
Ponens Dilemma
∴Q ¬Q
∨ ¬S
∴ ¬P
∨ ¬R

P →Q
Modus
¬Q
Tollens
∴ ¬P

Explore our latest online courses and learn new skills at your own pace. Enroll and become a certified
expert to boost your career.

Addition
If P is a premise, we can use Addition rule to derive P ∨ Q.

P
∴P ∨Q

Example
Let P be the proposition, “He studies very hard” is true

Therefore − "Either he studies very hard Or he is a very bad student." Here Q is the proposition “he is a
very bad student”.

Conjunction
If P and Q are two premises, we can use Conjunction rule to derive P ∧ Q.

P
Q
∴P ∧Q

Example

Let P − “He studies very hard”


Let Q − “He is the best boy in the class”

Therefore − "He studies very hard and he is the best boy in the class"

Simplification
If P ∧ Q is a premise, we can use Simplification rule to derive P.

P ∧Q
∴P

Example
"He studies very hard and he is the best boy in the class", P ∧Q

Therefore − "He studies very hard"

Modus Ponens
If P and P → Q are two premises, we can use Modus Ponens to derive Q.

P →Q
P
∴Q

Example

"If you have a password, then you can log on to facebook", P →Q

"You have a password", P

Therefore − "You can log on to facebook"

Modus Tollens
If P → Q and ¬Q are two premises, we can use Modus Tollens to derive ¬P .

P →Q
¬Q
∴ ¬P

Example
"If you have a password, then you can log on to facebook", P →Q
"You cannot log on to facebook", ¬Q

Therefore − "You do not have a password "

Disjunctive Syllogism
If ¬P and P ∨ Q are two premises, we can use Disjunctive Syllogism to derive Q.

¬P
P ∨Q
∴Q

Example
"The ice cream is not vanilla flavored", ¬P

"The ice cream is either vanilla flavored or chocolate flavored", P ∨Q

Therefore − "The ice cream is chocolate flavored”

Hypothetical Syllogism
If P → Q and Q → R are two premises, we can use Hypothetical Syllogism to derive P → R

P →Q
Q→R
∴P →R

Example

"If it rains, I shall not go to school”, P →Q

"If I don't go to school, I won't need to do homework", Q →R

Therefore − "If it rains, I won't need to do homework"

Constructive Dilemma
If (P
→ Q) ∧ (R → S) and P ∨ R are two premises, we can use constructive dilemma to derive
Q ∨ S.

(P → Q) ∧ (R → S)
P ∨R
∴Q∨S
Example
“If it rains, I will take a leave”, (P → Q)

“If it is hot outside, I will go for a shower”, (R → S)

“Either it will rain or it is hot outside”, P ∨R

Therefore − "I will take a leave or I will go for a shower"

Destructive Dilemma
If (P → Q) ∧ (R → S) and ¬Q ∨ ¬S are two premises, we can use destructive dilemma to
derive ¬P ∨ ¬R.

(P → Q) ∧ (R → S)
¬Q ∨ ¬S
∴ ¬P ∨ ¬R

Example
“If it rains, I will take a leave”, (P → Q)

“If it is hot outside, I will go for a shower”, (R → S)

“Either I will not take a leave or I will not go for a shower”, ¬Q ∨ ¬S

Therefore − "Either it does not rain or it is not hot outside"


Operators & Postulates
Group Theory is a branch of mathematics and abstract algebra that defines an algebraic structure
named as group. Generally, a group comprises of a set of elements and an operation over any two
elements on that set to form a third element also in that set.

In 1854, Arthur Cayley, the British Mathematician, gave the modern definition of group for the first time

“A set of symbols all of them different, and such that the product of any two of them (no
matter in what order), or the product of any one of them into itself, belongs to the set, is
said to be a group. These symbols are not in general convertible [commutative], but are
associative.”

In this chapter, we will know about operators and postulates that form the basics of set theory, group
theory and Boolean algebra.

Any set of elements in a mathematical system may be defined with a set of operators and a number
of postulates.

A binary operator defined on a set of elements is a rule that assigns to each pair of elements a unique
element from that set. For example, given the set A = {1, 2, 3, 4, 5}, we can say ⊗ is a binary
operator for the operation c = a ⊗ b, if it specifies a rule for finding c for the pair of (a, b), such that
a, b, c ∈ A.

The postulates of a mathematical system form the basic assumptions from which rules can be
deduced. The postulates are −

Closure
A set is closed with respect to a binary operator if for every pair of elements in the set, the operator
finds a unique element from that set.

Example

Let A = {0, 1, 2, 3, 4, 5, …}

This set is closed under binary operator into ( ∗ ), because for the operation c = a ∗ b, for any a, b ∈ A
, the product c ∈ A.

The set is not closed under binary operator divide ( ÷ ), because, for the operation c = a ÷ b, for any
a, b ∈ A, the product c may not be in the set A. If a = 7, b = 2, then c = 3.5. Here a, b ∈ A but c ∉ A.
Associative Laws
A binary operator ⊗ on a set A is associative when it holds the following property −

(x ⊗ y) ⊗ z = x ⊗ (y ⊗ z), where x, y, z ∈ A

Example
Let A = {1, 2, 3, 4}

The operator plus ( + ) is associative because for any three elements, x, y, z ∈ A, the property
(x + y) + z = x + (y + z) holds.

The operator minus ( − ) is not associative since

(x − y) − z ≠ x − (y − z)

Explore our latest online courses and learn new skills at your own pace. Enroll and become a certified
expert to boost your career.

Commutative Laws
A binary operator ⊗ on a set A is commutative when it holds the following property −

x ⊗ y = y ⊗ x, where x, y ∈ A

Example
Let A = {1, 2, 3, 4}

The operator plus ( + ) is commutative because for any two elements, x, y ∈ A, the property
x + y = y + x holds.

The operator minus ( − ) is not associative since

x−y≠y−x

Distributive Laws
Two binary operators ⊗ and ⊛ on a set A, are distributive over operator ⊛ when the following
property holds −

x ⊗ (y ⊛ z) = (x ⊗ y) ⊛ (x ⊗ z), where x, y, z ∈ A

Example

Let A = {1, 2, 3, 4}
The operators into ( ∗ ) and plus ( + ) are distributive over operator + because for any three elements,
x, y, z ∈ A, the property x ∗ (y + z) = (x ∗ y) + (x ∗ z) holds.

However, these operators are not distributive over ∗ since

x + (y ∗ z) ≠ (x + y) ∗ (x + z)

Identity Element
A set A has an identity element with respect to a binary operation ⊗ on A, if there exists an element
e ∈ A, such that the following property holds −

e ⊗ x = x ⊗ e, where x ∈ A

Example
Let Z = {0, 1, 2, 3, 4, 5, …}

The element 1 is an identity element with respect to operation ∗ since for any element x ∈ Z,

1∗x=x∗1

On the other hand, there is no identity element for the operation minus ( − )

Inverse
If a set A has an identity element e with respect to a binary operator ⊗ , it is said to have an inverse
whenever for every element x ∈ A, there exists another element y ∈ A, such that the following
property holds −

x⊗y=e

Example
Let A = {⋯ − 4, − 3, − 2, − 1, 0, 1, 2, 3, 4, 5, …}

Given the operation plus ( + ) and e = 0, the inverse of any element x is ( − x) since x + (x) = 0

De Morgan's Law
De Morgan’s Laws gives a pair of transformations between union and intersection of two (or more)
sets in terms of their complements. The laws are −

(A ∪ B) ′ = A ′ ∩ B ′

(A ∩ B) ′ = A ′ ∪ B ′

Example
Let A = {1, 2, 3, 4}, B = {1, 3, 5, 7}, and

Universal set U = {1, 2, 3, …, 9, 10}

A ′ = {5, 6, 7, 8, 9, 10}

B ′ = {2, 4, 6, 8, 9, 10}

A ∪ B = {1, 2, 3, 4, 5, 7}

A ∩ B = {1, 3}

(A ∪ B) ′ = {6, 8, 9, 10}

A ′ ∩ B ′ = {6, 8, 9, 10}

Thus, we see that (A ∪ B) ′ = A ′ ∩ B ′

(A ∩ B) ′ = {2, 4, 5, 6, 7, 8, 9, 10}

A ′ ∪ B ′ = {2, 4, 5, 6, 7, 8, 9, 10}

Thus, we see that (A ∩ B) ′ = A ′ ∪ B ′


Discrete Mathematics - Counting Theory
In daily lives, many a times one needs to find out the number of all possible outcomes for a series of
events. For instance, in how many ways can a panel of judges comprising of 6 men and 4 women be
chosen from among 50 men and 38 women? How many different 10 lettered PAN numbers can be
generated such that the first five letters are capital alphabets, the next four are digits and the last is
again a capital letter. For solving these problems, mathematical theory of counting are used. Counting
mainly encompasses fundamental counting rule, the permutation rule, and the combination rule.

The Rules of Sum and Product


The Rule of Sum and Rule of Product are used to decompose difficult counting problems into simple
problems.

The Rule of Sum − If a sequence of tasks T 1, T 2, …, T m can be done in w 1, w 2, …w m ways


respectively (the condition is that no tasks can be performed simultaneously), then the
number of ways to do one of these tasks is w 1 + w 2 + ⋯ + w m. If we consider two tasks A
and B which are disjoint (i.e. A ∩ B = ∅), then mathematically | A ∪ B | = | A | + | B |

The Rule of Product − If a sequence of tasks T 1, T 2, …, T m can be done in w 1, w 2, …w m ways


respectively and every task arrives after the occurrence of the previous task, then there are
w 1 × w 2 × ⋯ × w m ways to perform the tasks. Mathematically, if a task B arrives after a task
A, then | A × B | = | A | × | B |

Example

Question − A boy lives at X and wants to go to School at Z. From his home X he has to first reach Y
and then Y to Z. He may go X to Y by either 3 bus routes or 2 train routes. From there, he can either
choose 4 bus routes or 5 train routes to reach Z. How many ways are there to go from X to Z?

Solution − From X to Y, he can go in 3 + 2 = 5 ways (Rule of Sum). Thereafter, he can go Y to Z in


4 + 5 = 9 ways (Rule of Sum). Hence from X to Z he can go in 5 × 9 = 45 ways (Rule of Product).

Permutations
A permutation is an arrangement of some elements in which order matters. In other words a
Permutation is an ordered Combination of elements.

Examples

From a set S ={x, y, z} by taking two at a time, all permutations are −


xy, yx, xz, zx, yz, zy.
We have to form a permutation of three digit numbers from a set of numbers S = {1, 2, 3}.
Different three digit numbers will be formed when we arrange the digits. The permutation will
be = 123, 132, 213, 231, 312, 321

Number of Permutations

The number of permutations of ‘n’ different things taken ‘r’ at a time is denoted by n P
r

n!
nP =
r (n − r) !

where n ! = 1.2.3.…(n − 1). n

Proof − Let there be ‘n’ different elements.

There are n number of ways to fill up the first place. After filling the first place (n-1) number of
elements is left. Hence, there are (n-1) ways to fill up the second place. After filling the first and
second place, (n-2) number of elements is left. Hence, there are (n-2) ways to fill up the third place. We
can now generalize the number of ways to fill up r-th place as [n – (r–1)] = n–r+1

So, the total no. of ways to fill up from first place up to r-th-place −

n P = n(n − 1)(n − 2). . . . . (n − r + 1)


r

= [n(n − 1)(n − 2). . . (n − r + 1)][(n − r)(n − r − 1)…3.2.1] / [(n − r)(n − r − 1)…3.2.1]

Hence,

n P = n ! / (n − r) !
r

Some important formulas of permutation

If there are n elements of which a 1 are alike of some kind, a 2 are alike of another kind; a 3 are
alike of third kind and so on and a r are of r th kind, where (a 1 + a 2 + . . . a r) = n.
Then, number of permutations of these n objects is = n ! / [(a 1 !(a 2 !)…(a r !)].

Number of permutations of n distinct elements taking n elements at a time = n P = n !


n

The number of permutations of n dissimilar elements taking r elements at a time, when x


particular things always occupy definite places = n − x p
r−x

The number of permutations of n dissimilar elements when r specified things always come
together is − r !(n − r + 1) !
The number of permutations of n dissimilar elements when r specified things never come
together is − n !– [r !(n − r + 1) !]

The number of circular permutations of n different elements taken x elements at time = np x / x


The number of circular permutations of n different things = np n / n

Some Problems
Problem 1 − From a bunch of 6 different cards, how many ways we can permute it?

Solution − As we are taking 6 cards at a time from a deck of 6 cards, the permutation will be
6
P 6 = 6 ! = 720

Problem 2 − In how many ways can the letters of the word 'READER' be arranged?

Solution − There are 6 letters word (2 E, 1 A, 1D and 2R.) in the word 'READER'.

The permutation will be = 6 ! / [(2 !)(1 !)(1 !)(2 !)] = 180.

Problem 3 − In how ways can the letters of the word 'ORANGE' be arranged so that the consonants
occupy only the even positions?

Solution − There are 3 vowels and 3 consonants in the word 'ORANGE'. Number of ways of arranging
the consonants among themselves = 3P 3 = 3 ! = 6. The remaining 3 vacant places will be filled up by
3 vowels in 3P 3 = 3 ! = 6 ways. Hence, the total number of permutation is 6 × 6 = 36

Explore our latest online courses and learn new skills at your own pace. Enroll and become a certified
expert to boost your career.

Combinations
A combination is selection of some given elements in which order does not matter.

The number of all combinations of n things, taken r at a time is −

nC n!
r =
r !(n − r) !

Problem 1

Find the number of subsets of the set {1, 2, 3, 4, 5, 6} having 3 elements.

Solution

The cardinality of the set is 6 and we have to choose 3 elements from the set. Here, the ordering does
not matter. Hence, the number of subsets will be 6C 3 = 20.

Problem 2

There are 6 men and 5 women in a room. In how many ways we can choose 3 men and 2 women from
the room?

Solution
The number of ways to choose 3 men from 6 men is 6C 3 and the number of ways to choose 2 women
from 5 women is 5C 2

Hence, the total number of ways is − 6C 3 × 5C 2 = 20 × 10 = 200

Problem 3

How many ways can you choose 3 distinct groups of 3 students from total 9 students?

Solution

Let us number the groups as 1, 2 and 3

For choosing 3 students for 1st group, the number of ways − 9C 3

The number of ways for choosing 3 students for 2nd group after choosing 1st group − 6C 3

The number of ways for choosing 3 students for 3rd group after choosing 1st and 2nd group − 3C 3

Hence, the total number of ways = 9C 3 × 6C 3 × 3C 3 = 84 × 20 × 1 = 1680

Pascal's Identity

Pascal's identity, first derived by Blaise Pascal in 17th century, states that the number of ways to
choose k elements from n elements is equal to the summation of number of ways to choose (k-1)
elements from (n-1) elements and the number of ways to choose elements from n-1 elements.

1 1
Mathematically, for any positive integers k and n: nC k = n − C k − 1 + n − C k

Proof −

n − 1C 1
+n − Ck
k−1

(n−1) ! (n−1) !
= (k−1) ! (n−k) !
+ k! (n−k−1) !

k n−k
= (n − 1) !( + )
k! (n−k) ! k! (n−k) !

n
= (n − 1) ! k ! ( n − k ) !

n!
= k! (n−k) !

= nC
k

Pigeonhole Principle
In 1834, German mathematician, Peter Gustav Lejeune Dirichlet, stated a principle which he called the
drawer principle. Now, it is known as the pigeonhole principle.

Pigeonhole Principle states that if there are fewer pigeon holes than total number of pigeons and
each pigeon is put in a pigeon hole, then there must be at least one pigeon hole with more than one
pigeon. If n pigeons are put into m pigeonholes where n > m, there's a hole with more than one pigeon.

Examples

Ten men are in a room and they are taking part in handshakes. If each person shakes hands
at least once and no man shakes the same man’s hand more than once then two men took
part in the same number of handshakes.
There must be at least two people in a class of 30 whose names start with the same
alphabet.

The Inclusion-Exclusion principle


The Inclusion-exclusion principle computes the cardinal number of the union of multiple non-disjoint
sets. For two sets A and B, the principle states −

|A ∪ B| = |A| + |B| − |A ∩ B|

For three sets A, B and C, the principle states −

|A ∪ B ∪ C| = |A| + |B| + |C| − |A ∩ B| − |A ∩ C| − |B ∩ C| + |A ∩ B ∩ C|

The generalized formula -

| ⋃ ni= 1A i | = ∑ | Ai ∩ Aj | + ∑ | A i ∩ A j ∩ A k | − ⋯ + ( − 1) \n − 1 | A 1 ∩ ⋯ ∩ A 2 |
1≤i<j<k≤n 1≤i<j<k≤n

Problem 1

How many integers from 1 to 50 are multiples of 2 or 3 but not both?

Solution

From 1 to 100, there are 50 / 2 = 25 numbers which are multiples of 2.

There are 50 / 3 = 16 numbers which are multiples of 3.

There are 50 / 6 = 8 numbers which are multiples of both 2 and 3.

So, | A | = 25, | B | = 16 and | A ∩ B | = 8.

| A ∪ B | = | A | + | B | − | A ∩ B | = 25 + 16 − 8 = 33

Problem 2
In a group of 50 students 24 like cold drinks and 36 like hot drinks and each student likes at least one
of the two drinks. How many like both coffee and tea?

Solution

Let X be the set of students who like cold drinks and Y be the set of people who like hot drinks.

So, | X ∪ Y | = 50, | X | = 24, | Y | = 36

| X ∩ Y | = | X | + | Y | − | X ∪ Y | = 24 + 36 − 50 = 60 − 50 = 10

Hence, there are 10 students who like both tea and coffee.
Mathematical Induction
Mathematical induction, is a technique for proving results or establishing statements for natural
numbers. This part illustrates the method through a variety of examples.

Definition
Mathematical Induction is a mathematical technique which is used to prove a statement, a formula or
a theorem is true for every natural number.

The technique involves two steps to prove a statement, as stated below −

Step 1(Base step) − It proves that a statement is true for the initial value.

Step 2(Inductive step) − It proves that if the statement is true for the nth iteration (or number n), then
it is also true for (n+1)th iteration ( or number n+1).

How to Do It
Step 1 − Consider an initial value for which the statement is true. It is to be shown that the statement
is true for n = initial value.

Step 2 − Assume the statement is true for any value of n = k. Then prove the statement is true for n =
k+1. We actually break n = k+1 into two parts, one part is n = k (which is already proved) and try to
prove the other part.

Problem 1
3n − 1 is a multiple of 2 for n = 1, 2, ...

Solution

Step 1 − For n = 1, 31 − 1 = 3 − 1 = 2 which is a multiple of 2

Step 2 − Let us assume 3n − 1 is true for n = k, Hence, 3k − 1 is true (It is an assumption)

We have to prove that 3k+1 − 1 is also a multiple of 2

3k+1 − 1 = 3 × 3k − 1 = (2 × 3k )
+ (3k − 1)

The first part (2 × 3k) is certain to be a multiple of 2 and the second part (3k − 1) is also true as
our previous assumption.

Hence, 3k+1 – 1 is a multiple of 2.


So, it is proved that 3n – 1 is a multiple of 2.

Problem 2

1 + 3 + 5+. . . +(2n − 1) = n2 for n = 1, 2, …

Solution

Step 1 − For n = 1, 1 = 12 , Hence, step 1 is satisfied.

Step 2 − Let us assume the statement is true for n = k.

Hence, 1 + 3 + 5 + ⋯ + (2k − 1) = k2 is true (It is an assumption)

We have to prove that 1 + 3 + 5+. . . +(2(k + 1) − 1) also holds


= (k + 1)2

1 + 3 + 5 + ⋯ + (2(k + 1) − 1)

= 1 + 3 + 5 + ⋯ + (2k + 2 − 1)

= 1 + 3 + 5 + ⋯ + (2k + 1)

= 1 + 3 + 5 + ⋯ + (2k − 1)
+ (2k + 1)

= k2 + (2k + 1)

= (k + 1)2

So, 1 + 3 + 5 + ⋯ + (2(k + 1) − 1) hold which satisfies the step 2.


= (k + 1)2

Hence, 1 + 3 + 5 + ⋯ + (2n − 1) = n2 is proved.

Problem 3

Prove that (ab)n = an bn is true for every natural number n

Solution

Step 1 − For n = 1, (ab)1 = a1 b1 = ab , Hence, step 1 is satisfied.

Step 2 − Let us assume the statement is true for n = k, Hence, (ab)k = ak bk is true (It is an
assumption).

We have to prove that (ab)k+1 = ak+1 bk+1 also hold

Given, (ab)k = ak bk
Or, (ab)k (ab) = (ak bk )(ab) [Multiplying both side by 'ab']

Or, (ab)k+1 = (aak )(bbk )

Or, (ab)k+1 = (ak+1 bk+1 )

Hence, step 2 is proved.

So, (ab)n = an bn is true for every natural number n.

Explore our latest online courses and learn new skills at your own pace. Enroll and become a certified
expert to boost your career.

Strong Induction
Strong Induction is another form of mathematical induction. Through this induction technique, we can
prove that a propositional function, P (n) is true for all positive integers, n , using the following steps

Step 1(Base step) − It proves that the initial proposition P (1) true.
Step 2(Inductive step) − It proves that the conditional statement
[P (1) ∧ P (2) ∧ P (3) ∧ ⋯ ∧ P (k)] is true for positive integers k .
→ P (k + 1)
Discrete Mathematics - Recurrence Relation
In this chapter, we will discuss how recursive techniques can derive sequences and be used for
solving counting problems. The procedure for finding the terms of a sequence in a recursive manner
is called recurrence relation. We study the theory of linear recurrence relations and their solutions.
Finally, we introduce generating functions for solving recurrence relations.

Definition
A recurrence relation is an equation that recursively defines a sequence where the next term is a
function of the previous terms (Expressing F n as some combination of F i with i < n).

Example − Fibonacci series − F n = F n − 1 + F n − 2, Tower of Hanoi − F n = 2F n − 1 + 1

Linear Recurrence Relations


A linear recurrence equation of degree k or order k is a recurrence equation which is in the format
x n = A 1x n − 1 + A 2x n − 1 + A 3x n − 1 + …A kx n − k(A n is a constant and A k ≠ 0) on a sequence of
numbers as a first-degree polynomial.

These are some examples of linear recurrence equations −

Recurrence relations Initial values Solutions

Fn = Fn-1 + Fn-2 a1 = a2 = 1 Fibonacci number

Fn = Fn-1 + Fn-2 a1 = 1, a2 = 3 Lucas Number

Fn = Fn-2 + Fn-3 a1 = a2 = a3 = 1 Padovan sequence

Fn = 2Fn-1 + Fn-2 a1 = 0, a2 = 1 Pell number

How to solve linear recurrence relation

Suppose, a two ordered linear recurrence relation is − F n = AF n − 1 + BF n − 2 where A and B are real
numbers.

The characteristic equation for the above recurrence relation is −

x 2 − Ax − B = 0

Three cases may occur while finding the roots −


Case 1 − If this equation factors as (x − x 1)(x − x 1) = 0 and it produces two distinct real roots x 1 and
x 2, then F n = ax n1 + bx n2 is the solution. [Here, a and b are constants]

Case 2 − If this equation factors as (x − x 1) 2 = 0 and it produces single real root x 1, then
n n
F n = ax 1 + bnx 1 is the solution.

Case 3 − If the equation produces two distinct complex roots, x 1 and x 2 in polar form x 1 = r∠θ and
x 2 = r∠( − θ), then F n = r n(acos(nθ) + bsin(nθ)) is the solution.

Problem 1

Solve the recurrence relation F n = 5F n − 1 − 6F n − 2 where F 0 = 1 and F 1 = 4

Solution

The characteristic equation of the recurrence relation is −

x 2 − 5x + 6 = 0,

So, (x − 3)(x − 2) = 0

Hence, the roots are −

x 1 = 3 and x 2 = 2

The roots are real and distinct. So, this is in the form of case 1

Hence, the solution is −

n n
F n = ax 1 + bx 2

Here, F n = a3 n + b2 n (As x 1 = 3 and x 2 = 2)

Therefore,

1 = F 0 = a3 0 + b2 0 = a + b

4 = F 1 = a3 1 + b2 1 = 3a + 2b

Solving these two equations, we get a = 2 and b = − 1

Hence, the final solution is −

F n = 2.3 n + ( − 1). 2 n = 2.3 n − 2 n

Problem 2

Solve the recurrence relation − F n = 10F n − 1 − 25F n − 2 where F 0 = 3 and F 1 = 17

Solution
The characteristic equation of the recurrence relation is −

x 2 − 10x − 25 = 0

So (x − 5) 2 = 0

Hence, there is single real root x 1 = 5

As there is single real valued root, this is in the form of case 2

Hence, the solution is −

F n = ax n1 + bnx n1

3 = F 0 = a.5 0 + (b)(0.5) 0 = a

17 = F 1 = a.5 1 + b.1.5 1 = 5a + 5b

Solving these two equations, we get a = 3 and b = 2 / 5

Hence, the final solution is − F n = 3.5 n + (2 / 5). n.2 n

Problem 3

Solve the recurrence relation F n = 2F n − 1 − 2F n − 2 where F 0 = 1 and F 1 = 3

Solution

The characteristic equation of the recurrence relation is −

x 2 − 2x − 2 = 0

Hence, the roots are −

x 1 = 1 + i and x 2 = 1 − i

In polar form,

π
x 1 = r∠θ and x 2 = r∠( − θ), where r = √2 and θ = 4

The roots are imaginary. So, this is in the form of case 3.

Hence, the solution is −

F n = (√2) n(acos(n. ⊓ / 4) + bsin(n. ⊓ / 4))

1 = F 0 = (√2) 0(acos(0. ⊓ / 4) + bsin(0. ⊓ / 4)) = a

3 = F 1 = (√2) 1(acos(1. ⊓ / 4) + bsin(1. ⊓ / 4)) = √2(a / √2 + b / √2)


Solving these two equations we get a = 1 and b = 2
Hence, the final solution is −

F n = (√2) n(cos(n. π / 4) + 2sin(n. π / 4))

Explore our latest online courses and learn new skills at your own pace. Enroll and become a certified
expert to boost your career.

Non-Homogeneous Recurrence Relation and Particular Solutions


A recurrence relation is called non-homogeneous if it is in the form

F n = AF n − 1 + BF n − 2 + f(n) where f(n) ≠ 0

Its associated homogeneous recurrence relation is F n = AF n – 1 + BF n − 2

The solution (a n) of a non-homogeneous recurrence relation has two parts.

First part is the solution (a h) of the associated homogeneous recurrence relation and the second part
is the particular solution (a t).

an = ah + at

Solution to the first part is done using the procedures discussed in the previous section.

To find the particular solution, we find an appropriate trial solution.

Let f(n) = cx n ; let x 2 = Ax + B be the characteristic equation of the associated homogeneous


recurrence relation and let x 1 and x 2 be its roots.

If x ≠ x 1 and x ≠ x 2, then a t = Ax n

If x = x 1, x ≠ x 2, then a t = Anx n

If x = x 1 = x 2, then a t = An 2x n

Example
Let a non-homogeneous recurrence relation be F n = AF n – 1 + BF n − 2 + f(n) with characteristic roots
x 1 = 2 and x 2 = 5. Trial solutions for different possible values of f(n) are as follows −

f(n) Trial solutions

4 A

5.2n An2n

8.5n An5n
4n A4n

2n2+3n+1 An2+Bn+C

Problem

Solve the recurrence relation F n = 3F n − 1 + 10F n − 2 + 7.5 n where F 0 = 4 and F 1 = 3

Solution

This is a linear non-homogeneous relation, where the associated homogeneous equation is


F n = 3F n − 1 + 10F n − 2 and f(n) = 7.5 n

The characteristic equation of its associated homogeneous relation is −

x 2 − 3x − 10 = 0

Or, (x − 5)(x + 2) = 0

Or, x 1 = 5 and x 2 = − 2

Hence a h = a.5 n + b. ( − 2) n , where a and b are constants.

Since f(n) = 7.5 n, i.e. of the form c. x n, a reasonable trial solution of at will be Anx n

a t = Anx n = An5 n

After putting the solution in the recurrence relation, we get −

An5 n = 3A(n– 1)5 n − 1 + 10A(n– 2)5 n − 2 + 7.5 n

Dividing both sides by 5 n − 2, we get

An5 2 = 3A(n − 1)5 + 10A(n − 2)5 0 + 7.5 2

Or, 25An = 15An − 15A + 10An − 20A + 175

Or, 35A = 175

Or, A=5

So, F n = An5 n = 5n5 n = n5 n + 1

The solution of the recurrence relation can be written as −

Fn = ah + at

= a.5 n + b. ( − 2) n + n5 n + 1

Putting values of F 0 = 4 and F 1 = 3, in the above equation, we get a = − 2 and b = 6


Hence, the solution is −

F n = n5 n + 1 + 6.( − 2) n − 2.5 n

Generating Functions
Generating Functions represents sequences where each term of a sequence is expressed as a
coefficient of a variable x in a formal power series.

Mathematically, for an infinite sequence, say a 0, a 1, a 2, …, a k, …, the generating function will be −


G x = a 0 + a 1 x + a 2 x + ⋯ + a kx + ⋯ =
2 k
∑ a kx k
k=0

Some Areas of Application


Generating functions can be used for the following purposes −

For solving a variety of counting problems. For example, the number of ways to make change
for a Rs. 100 note with the notes of denominations Rs.1, Rs.2, Rs.5, Rs.10, Rs.20 and Rs.50
For solving recurrence relations

For proving some of the combinatorial identities


For finding asymptotic formulae for terms of sequences

Problem 1

What are the generating functions for the sequences {a k} with a k = 2 and a k = 3k?

Solution

When a k = 2, generating function, G(x) = ∑ ∞ k 2 3


k = 02x = 2 + 2x + 2x + 2x + …

When a k = 3k, G(x) = ∑ ∞ k 2 3


k = 03kx = 0 + 3x + 6x + 9x + ……

Problem 2

What is the generating function of the infinite series; 1, 1, 1, 1, …?

Solution

Here, a k = 1, for 0 ≤ k ≤ ∞

1
Hence, G(x) = 1 + x + x 2 + x 3 + …⋯ = (1−x)
Some Useful Generating Functions

For a k = a k, G(x) = ∑ ∞
k=0
a kx k = 1 + ax + a 2x 2 + ……⋯ = 1 / (1 − ax)

∞ 1
For a k = (k + 1), G(x) = ∑ k = 0(k + 1)x k = 1 + 2x + 3x 2……⋯ =
( 1 − x )2

For a k = c nk, G(x) = ∑ ∞ c nx k = 1 + c n1 x + c n2 x 2 + ……⋯ + x 2 = (1 + x) n


k=0 k

1 xk x2 x3
For a k = , G(x) = ∑ ∞
k=0
=1+x+ + ……⋯ = e x
k! k! 2! 3!
Graph & Graph Models
The previous part brought forth the different tools for reasoning, proofing and problem solving. In this
part, we will study the discrete structures that form the basis of formulating many a real-life problem.

The two discrete structures that we will cover are graphs and trees. A graph is a set of points, called
nodes or vertices, which are interconnected by a set of lines called edges. The study of graphs, or
graph theory is an important part of a number of disciplines in the fields of mathematics, engineering
and computer science.

What is a Graph?
Definition − A graph (denoted as G = (V , E)) consists of a non-empty set of vertices or nodes V
and a set of edges E.

Example − Let us consider, a Graph is G = (V , E) where V = {a, b, c, d} and


E = {{a, b}, {a, c}, {b, c}, {c, d}}

Degree of a Vertex − The degree of a vertex V of a graph G (denoted by deg (V)) is the number of
edges incident with the vertex V.

Vertex Degree Even / Odd

a 2 even

b 2 even

c 3 odd

d 1 odd

Even and Odd Vertex − If the degree of a vertex is even, the vertex is called an even vertex and if the
degree of a vertex is odd, the vertex is called an odd vertex.

Degree of a Graph − The degree of a graph is the largest vertex degree of that graph. For the above
graph the degree of the graph is 3.
The Handshaking Lemma − In a graph, the sum of all the degrees of all the vertices is equal to twice
the number of edges.

Types of Graphs
There are different types of graphs, which we will learn in the following section.

Null Graph

A null graph has no edges. The null graph of n vertices is denoted by Nn

Simple Graph

A graph is called simple graph/strict graph if the graph is undirected and does not contain any loops
or multiple edges.

Multi-Graph

If in a graph multiple edges between the same set of vertices are allowed, it is called Multigraph. In
other words, it is a graph having at least one loop or multiple edges.
Directed and Undirected Graph
A graph G = (V , E) is called a directed graph if the edge set is made of ordered vertex pair and a
graph is called undirected if the edge set is made of unordered vertex pair.

Connected and Disconnected Graph


A graph is connected if any two vertices of the graph are connected by a path; while a graph is
disconnected if at least two vertices of the graph are not connected by a path. If a graph G is
disconnected, then every maximal connected subgraph of G is called a connected component of the
graph G.
Regular Graph

A graph is regular if all the vertices of the graph have the same degree. In a regular graph G of degree
r, the degree of each vertex of G is r.

Complete Graph
A graph is called complete graph if every two vertices pair are joined by exactly one edge. The
complete graph with n vertices is denoted by Kn
Cycle Graph
If a graph consists of a single cycle, it is called cycle graph. The cycle graph with n vertices is denoted
by Cn

Bipartite Graph
If the vertex-set of a graph G can be split into two disjoint sets, V1 and V2 , in such a way that each
edge in the graph joins a vertex in V1 to a vertex in V2 , and there are no edges in G that connect two
vertices in V1 or two vertices in V2 , then the graph G is called a bipartite graph.
Complete Bipartite Graph
A complete bipartite graph is a bipartite graph in which each vertex in the first set is joined to every
single vertex in the second set. The complete bipartite graph is denoted by Kx,y where the graph G
contains x vertices in the first set and y vertices in the second set.

Explore our latest online courses and learn new skills at your own pace. Enroll and become a certified
expert to boost your career.

Representation of Graphs
There are mainly two ways to represent a graph −

Adjacency Matrix

Adjacency List

Adjacency Matrix
An Adjacency Matrix A[V ][V ] is a 2D array of size V × V where V is the number of vertices in a
undirected graph. If there is an edge between Vx to Vy then the value of A[Vx ][Vy ] = 1 and
A[Vy ][Vx ] = 1 , otherwise the value will be zero. And for a directed graph, if there is an edge between
Vx to Vy , then the value of A[Vx ][Vy ] = 1 , otherwise the value will be zero.

Adjacency Matrix of an Undirected Graph

Let us consider the following undirected graph and construct the adjacency matrix −

Adjacency matrix of the above undirected graph will be −

a b c d

a 0 1 1 0

b 1 0 1 0

c 1 1 0 1

d 0 0 1 0

Adjacency Matrix of a Directed Graph

Let us consider the following directed graph and construct its adjacency matrix −

Adjacency matrix of the above directed graph will be −


a b c d

a 0 1 1 0

b 0 0 1 0

c 0 0 0 1

d 0 0 0 0

Adjacency List
In adjacency list, an array (A[V ]) of linked lists is used to represent the graph G with V number of
vertices. An entry A[Vx ] represents the linked list of vertices adjacent to the V x − th vertex. The
adjacency list of the undirected graph is as shown in the figure below −

Planar vs. Non-planar graph


Planar graph − A graph G is called a planar graph if it can be drawn in a plane without any edges
crossed. If we draw graph in the plane without edge crossing, it is called embedding the graph in the
plane.
Non-planar graph − A graph is non-planar if it cannot be drawn in a plane without graph edges
crossing.

Isomorphism
If two graphs G and H contain the same number of vertices connected in the same way, they are
called isomorphic graphs (denoted by G ≅H ).

It is easier to check non-isomorphism than isomorphism. If any of these following conditions occurs,
then two graphs are non-isomorphic −

The number of connected components are different

Vertex-set cardinalities are different

Edge-set cardinalities are different

Degree sequences are different

Example
The following graphs are isomorphic −

Homomorphism
A homomorphism from a graph G to a graph H is a mapping (May not be a bijective mapping)
h : G → H such that − (x, y) ∈ E(G) → (h(x), h(y)) ∈ E(H) . It maps adjacent vertices of
graph G to the adjacent vertices of the graph H .

Properties of Homomorphisms

A homomorphism is an isomorphism if it is a bijective mapping.

Homomorphism always preserves edges and connectedness of a graph.

The compositions of homomorphisms are also homomorphisms.

To find out if there exists any homomorphic graph of another graph is a NPcomplete problem.

Euler Graphs
A connected graph G is called an Euler graph, if there is a closed trail which includes every edge of
the graph G. An Euler path is a path that uses every edge of a graph exactly once. An Euler path starts
and ends at different vertices.

An Euler circuit is a circuit that uses every edge of a graph exactly once. An Euler circuit always starts
and ends at the same vertex. A connected graph G is an Euler graph if and only if all vertices of G are
of even degree, and a connected graph G is Eulerian if and only if its edge set can be decomposed
into cycles.

The above graph is an Euler graph as “a 1 b 2 c 3 d 4 e 5 c 6 f 7 g” covers all the edges of the
graph.
Hamiltonian Graphs
A connected graph G is called Hamiltonian graph if there is a cycle which includes every vertex of G
and the cycle is called Hamiltonian cycle. Hamiltonian walk in graph G is a walk that passes through
each vertex exactly once.

n
If G is a simple graph with n vertices, where n ≥ 3 If deg(v) ≥ 2
for each vertex v, then the graph
G is Hamiltonian graph. This is called Dirac's Theorem.

If G is a simple graph with n vertices, where n ≥ 2 if deg(x) + deg(y) ≥ n for each pair of non-
adjacent vertices x and y, then the graph G is Hamiltonian graph. This is called Ore's theorem.
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 a’s 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→b→d→e→c

The alternate orders of traversal are −

a→b→e→d→c

Or, a→d→b→e→c

Or, a→e→b→d→c

Or, a→b→e→d→c

Or, a→d→e→b→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(|V 2|)

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 a’s 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→b→c→d→e

The alternate orders of traversal are −

a→e→b→c→d

Or, a→b→e→c→d

Or, a→d→e→b→c

Or, a→d→c→e→b

Or, a→d→c→b→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 −
⊝(|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 Knight’s Tour problem

Solving puzzles with only one solution


Introduction to Trees
Tree is a discrete structure that represents hierarchical relationships between individual elements or
nodes. A tree in which a parent has no more than two children is called a binary tree.

Tree and its Properties


Definition − A Tree is a connected acyclic undirected graph. There is a unique path between every pair
of vertices in G. A tree with N number of vertices contains (N − 1) number of edges. The vertex
which is of 0 degree is called root of the tree. The vertex which is of 1 degree is called leaf node of the
tree and the degree of an internal node is at least 2.

Example − The following is an example of a tree −

Centers and Bi-Centers of a Tree


The center of a tree is a vertex with minimal eccentricity. The eccentricity of a vertex X in a tree G is
the maximum distance between the vertex X and any other vertex of the tree. The maximum
eccentricity is the tree diameter. If a tree has only one center, it is called Central Tree and if a tree has
only more than one centers, it is called Bi-central Tree. Every tree is either central or bi-central.

Algorithm to find centers and bi-centers of a tree

Step 1 − Remove all the vertices of degree 1 from the given tree and also remove their incident edges.

Step 2 − Repeat step 1 until either a single vertex or two vertices joined by an edge is left. If a single
vertex is left then it is the center of the tree and if two vertices joined by an edge is left then it is the bi-
center of the tree.

Problem 1

Find out the center/bi-center of the following tree −


Solution

At first, we will remove all vertices of degree 1 and also remove their incident edges and get the
following tree −

Again, we will remove all vertices of degree 1 and also remove their incident edges and get the
following tree −

Finally we got a single vertex ‘c’ and we stop the algorithm. As there is single vertex, this tree has one
center ‘c’ and the tree is a central tree.

Problem 2

Find out the center/bi-center of the following tree −


Solution

At first, we will remove all vertices of degree 1 and also remove their incident edges and get the
following tree −

Again, we will remove all vertices of degree 1 and also remove their incident edges and get the
following tree −

Finally, we got two vertices ‘c’ and ‘d’ left, hence we stop the algorithm. As two vertices joined by an
edge is left, this tree has bi-center ‘cd’ and the tree is bi-central.

Explore our latest online courses and learn new skills at your own pace. Enroll and become a certified
expert to boost your career.

Labeled Trees
Definition − A labeled tree is a tree the vertices of which are assigned unique numbers from 1 to n. We
can count such trees for small values of n by hand so as to conjecture a general formula. The number
of labeled trees of n number of vertices is nn−2 . Two labeled trees are isomorphic if their graphs are
isomorphic and the corresponding points of the two trees have the same labels.

Example
Unlabeled Trees
Definition − An unlabeled tree is a tree the vertices of which are not assigned any numbers. The
(2n)!
number of labeled trees of n number of vertices is (nth Catalan number)
(n+1)!n!

Example
Rooted Tree
A rooted tree G is a connected acyclic graph with a special node that is called the root of the tree and
every edge directly or indirectly originates from the root. An ordered rooted tree is a rooted tree where
the children of each internal vertex are ordered. If every internal vertex of a rooted tree has not more
than m children, it is called an m-ary tree. If every internal vertex of a rooted tree has exactly m
children, it is called a full m-ary tree. If m = 2, the rooted tree is called a binary tree.

Binary Search Tree


Binary Search tree is a binary tree which satisfies the following property −
X in left sub-tree of vertex V , V alue(X) ≤ V alue(V )
Y in right sub-tree of vertex V , V alue(Y ) ≥ V alue(V )

So, the value of all the vertices of the left sub-tree of an internal node V are less than or equal to V
and the value of all the vertices of the right sub-tree of the internal node V are greater than or equal to
V . The number of links from the root node to the deepest node is the height of the Binary Search Tree.

Example

Algorithm to search for a key in BST

BST_Search(x, k)
if ( x = NIL or k = Value[x] )
return x;
if ( k < Value[x])
return BST_Search (left[x], k);
else
return BST_Search (right[x], k)

Complexity of Binary search tree

Average Case Worst case

Space Complexity O(n) O(n)

Search Complexity O(log n) O(n)


Insertion Complexity O(log n) O(n)

Deletion Complexity O(log n) O(n)


Discrete Mathematics - Spanning Trees
A spanning tree of a connected undirected graph G is a tree that minimally includes all of the vertices
of G. A graph may have many spanning trees.

Example

Minimum Spanning Tree


A spanning tree with assigned weight less than or equal to the weight of every possible spanning tree
of a weighted, connected and undirected graph G, it is called minimum spanning tree (MST). The
weight of a spanning tree is the sum of all the weights assigned to each edge of the spanning tree.

Example
Kruskal's Algorithm
Kruskal's algorithm is a greedy algorithm that finds a minimum spanning tree for a connected
weighted graph. It finds a tree of that graph which includes every vertex and the total weight of all the
edges in the tree is less than or equal to every possible spanning tree.

Algorithm
Step 1 − Arrange all the edges of the given graph G(V , E) in ascending order as per their edge
weight.

Step 2 − Choose the smallest weighted edge from the graph and check if it forms a cycle with the
spanning tree formed so far.

Step 3 − If there is no cycle, include this edge to the spanning tree else discard it.

Step 4 − Repeat Step 2 and Step 3 until (V − 1) number of edges are left in the spanning tree.

Problem

Suppose we want to find minimum spanning tree for the following graph G using Kruskal’s algorithm.
Solution

From the above graph we construct the following table −

Edge No. Vertex Pair Edge Weight

E1 (a, b) 20

E2 (a, c) 9

E3 (a, d) 13

E4 (b, c) 1

E5 (b, e) 4

E6 (b, f) 5

E7 (c, d) 2

E8 (d, e) 3

E9 (d, f) 14

Now we will rearrange the table in ascending order with respect to Edge weight −

Edge No. Vertex Pair Edge Weight


E4 (b, c) 1

E7 (c, d) 2

E8 (d, e) 3

E5 (b, e) 4

E6 (b, f) 5

E2 (a, c) 9

E3 (a, d) 13

E9 (d, f) 14

E1 (a, b) 20
Since we got all the 5 edges in the last figure, we stop the algorithm and this is the minimal spanning
tree and its total weight is (1 + 2 + 3 + 5 + 9) = 20 .

Explore our latest online courses and learn new skills at your own pace. Enroll and become a certified
expert to boost your career.

Prim's Algorithm
Prim's algorithm, discovered in 1930 by mathematicians, Vojtech Jarnik and Robert C. Prim, is a
greedy algorithm that finds a minimum spanning tree for a connected weighted graph. It finds a tree
of that graph which includes every vertex and the total weight of all the edges in the tree is less than
or equal to every possible spanning tree. Prim’s algorithm is faster on dense graphs.
Algorithm

Initialize the minimal spanning tree with a single vertex, randomly chosen from the graph.

Repeat steps 3 and 4 until all the vertices are included in the tree.
Select an edge that connects the tree with a vertex not yet in the tree, so that the weight of
the edge is minimal and inclusion of the edge does not form a cycle.
Add the selected edge and the vertex that it connects to the tree.

Problem

Suppose we want to find minimum spanning tree for the following graph G using Prim’s algorithm.

Solution

Here we start with the vertex ‘a’ and proceed.


This is the minimal spanning tree and its total weight is (1 + 2 + 3 + 5 + 9) = 20 .

You might also like

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy