KEMBAR78
1.1 - Analysis of Algorithms | PDF | Algorithms | Programming
0% found this document useful (0 votes)
88 views37 pages

1.1 - Analysis of Algorithms

This document provides an introduction to algorithms and their analysis. It discusses the characteristics of algorithms, the difference between algorithms and programs, and why analyzing algorithms is important. It also covers iterative and recursive algorithms, asymptotic notations like Big-O notation used to analyze time and space complexity, and examples of iterative algorithms with their analysis including calculating complexity. The goal of algorithm analysis is to compare how resources like time and space required by algorithms grow as the input size increases.

Uploaded by

knambiardjs
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)
88 views37 pages

1.1 - Analysis of Algorithms

This document provides an introduction to algorithms and their analysis. It discusses the characteristics of algorithms, the difference between algorithms and programs, and why analyzing algorithms is important. It also covers iterative and recursive algorithms, asymptotic notations like Big-O notation used to analyze time and space complexity, and examples of iterative algorithms with their analysis including calculating complexity. The goal of algorithm analysis is to compare how resources like time and space required by algorithms grow as the input size increases.

Uploaded by

knambiardjs
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/ 37

Module 1

Basics of Algorithms
Ruchika Patil
Assistant Professor
CSE-DS
DJSCE
Contents:
❑ Introduction
❑ Characteristics of an Algorithm
❑ Algorithm vs Program
❑ Why analyze an algorithm?
❑ Performance Analysis – Time and Space
❑ Examples – Iterative algorithms
❑ Growth of functions
❑ Asymptotic Notations
Introduction
• What is Algorithm?
• a clearly specified set of simple instructions to be followed to solve a problem
Takes a set of values, as input and
• produces a value, or set of values, as output
• May be specified
• In English
• As a computer program
• As a pseudo-code
• Data structures
• Methods of organizing data
• Program = algorithms + data structures
Features/Criteria of an Algorithm:
1. Input: 0 or more

2. Output: Atleast 1

3. Definiteness: clear and unambiguous

4. Finiteness: terminate after a finite number of steps

1. Effectiveness: steps/instructions should be basic & effective


enough to be carried out.
Algorithm vs Program
• Algorithm:
- step-by-step procedure that allows a computer to solve a problem.
- Simple layman’s language without syntax. (Any language)
- Design phase
- H/w and OS independent

• Program
-It is exact code written for problem following all the rules of the
programming
language.
- Implementation phase
- H/w and software dependent
Why Analyze the Algorithms?
❑ Lets take an example…
⮚Predict Performance
⮚Compare algorithms
⮚Provide guarantees
❑ Goal:
- The goal of the analysis of algorithms is to compare algorithms
(or solutions) mainly in terms of running time but also in terms of other
factors (e.g., memory, developer effort, input size etc.)
Algorithm Analysis
• We only analyze correct algorithms
• Analyzing an algorithm
• Predicting the resources that the algorithm requires
• Resources include
• Memory
• Communication bandwidth
• Computational time (usually most important)
Performance Analysis of an
Algorithm
• Performance of algorithm should be measured rather than performance of its
implemented program.

• Performance analysis of an algorithm is the process of determining the resources ie,


space required by that algorithm and time required by that algorithm in order to
execute efficiently.

• While designing algorithms following factors should be focused:


• Space Complexity: Memory required includes program space and data space
• Time Complexity: Time required
Time & Space
Complexity
The Analysis of an algorithm refers to the process of deriving estimates for the
time and space needed to execute the algorithm.
Time complexity
• Time complexity of an algorithm is total time or basic steps
required needed by the algorithm to run to its completion depending
on the size of the input.

• Time requirements can be defined as a numerical function T(n),


where T(n) can be measured as the number of steps, provided each
step consumes constant time.

• The algorithm will take a different amount of time depending on the size of the
problem that it is presented with.

• commonly expressed using the big O notation.


Actual running time depends on?
How to approximate the time taken by the
Algorithm?
There are two types of algorithms:
• Iterative Algorithm: In the iterative approach, the function repeatedly runs
until the condition is met or it fails. It involves the looping construct.

• Recursive Algorithm: In the recursive approach, the function calls itself until
the condition is met. It integrates the branching structure.
Iterative Algorithm:
An iterative algorithm will use looping statements such as for, while or do-
while etc… to repeat the same steps.

Example 1: Swapping two numbers

Algorithm swap(x, y)
{ Time Complexity:
T(n) = 3
temp = x; = O(1)
x = y;
y = temp; Space complexity:
S(n) = 3 words
} = O(1)
Example:2 (Frequency count)
Finding sum of all elements in an
array.
Algorithm Sum( Arr, n)
{
sum = 0;
for (i = 0; i<n ; i++) Time Complexity:
{ T(n) = 2n+3
= O(n) - Linear
sum= sum+Arr[i];
} Space complexity:
S(n) = n+3
return sum; = O(n)
}
Tabular Method
Iterative function to sum a list of numbers

Statement s/e Frequency Total steps


float sum(float list[ ], int n) 0 0 0
{ 0 0 0
float tempsum = 0; 1 1 1
int i; 0 0 0
for(i=0; i <n; i++) 1 n+1 n+1
tempsum += list[i]; 1 n n
return tempsum; 1 1 1
} 0 0 0
Total 2n+3
Example: 3
Adding 2D matrices.

Algorithm Add(A, B, n)
{
for(i= 0 ; i < n ; i++)
{ Time Complexity:
T(n) = 2n2 +2n+1
for (j= 0 ; j < n ; j++) = O(n2)
{
Space complexity:
c[i,j] = A[i, j] +B [i, j]; S(n) = 3n2 +3
} = O(n2)
}
Example: 4
• 3 nested for loops.
for(i= 0 ; i < n ; i++)
{
for (j= 0 ; j < n ; j++)
{
for (k= 0; k<n ; k++)
{
statement;
}
}
}
Analysis of if-else condition:

if (condition)
{
statement ;
}
else
{
for (i= 0 to n )
{
statement
Answer:
;
} Best – O(1)
Worst- O(n)
}
Analysis of while loop
1) i =0 ;
while(i< n)
{
statement
; i++;
}
General Rules:
• Rule 1 - for loops: The running time of a for loop is at most the running time of
the statements inside the for loop times the number of iterations.

• Rule 2 - nested loops: Analyze these inside out. The total running time of a
statement inside a group of nested loops is the running time of the statement
multiplied by the product of the sizes of all the loops.

• Rule 3 - consecutive statements: These just add.

• Rule 4 - if/else: For the fragment if(condition) S1 else S2, the running time of an
if/else statement is never more than the running time of the test plus the larger of the
running times of S1 and S2.

• While loop- same as for loop


Space Complexity
• Space Complexity of an algorithm is amount of memory needed by the
algorithm to run to its completion. A program requires space for
1. Variables (This include the constant values, temporary values)
2. Program Instruction
3. Execution

Auxiliary Space is the extra space or the temporary space used by the algorithm during it's execution.
Space Complexity = Auxiliary Space + Input space
Example:

If we need to create an array of size n, this will require O(n) space. If we create a two-dimensional array of size n*n, this will require
O(n2) space.
Space Complexity
• Example:
• Algorithm: SUM(A, B)
• Step 1 - START
• Step 2 - C ← A + B + 10
• Step 3 - Stop

• Here we have three variables A, B, and C and one constant. Hence S(P) = 1 + 3.
Now, space depends on data types of given variables and constant types and it
will be multiplied accordingly.
Types of Analysis (Best, Average, Worst)

• Example : Search (array, x)


• Case I: x is the 1st element
• No. of checks =1

• Case II: x is not present


• No. of checks = n

• Case III: x is present, but not the 1st element


Types of Analysis (Best, Average, Worst)
• Worst-case: f (n) represent by the maximum number of steps taken
on any instance of size n.

• Best-case: f (n) represent by the minimum number of steps taken on


any instance of size n.

• Average case: f (n) represent by the average number of steps taken


on any instance of size n.
Asymptotic Notations
The word Asymptote means a line that approaches the curve of
the polynomial approximately(i.e., as some sort of limit is taken).
(Limiting behaviour)
Asymptotic Notations
• Asymptotic notations are the mathematical notations used to describe
the running time of an algorithm when the input tends towards a
particular value or a limiting value.

● The efficiency of an algorithm depends on the amount of time, storage and


other resources required to execute the algorithm. The efficiency is measured
with the help of asymptotic notations.
Asymptotic Notations
1) Big - Oh (O) : Upper bound → Worst Case
2) Big - Omega (Ω) : Lower bound → Best Case
3) Big - Theta (Θ) : Average bound → Average Case
GROWTH OF FUNCTIONS
• The order of growth of the running time of an algorithm give a
characterization of algorithm’s efficiency and help us to compare
the relative performance of alternative algorithms, when the input
size n becomes large enough.

• Asymptotic efficiency helps us to study order of growth of the running


time when input size becomes large enough.

• Asymptotic notation are to describe the running times of algorithms.


Runtime Analysis of Algorithm

1 < log n < 𝑛<n < n log n < n 2< n3 …… < nn


Typical Complexities of an
Algorithm
O (1) : Constant
O( log n) : Logarithmic
O( n ) : Linear
: Quadratic
O(n2 )
: Cubic
O(n3 )

O(2n ), O(n!) : Exponential


Function values
Big - Oh (O) : Upper Bound
• Definition: Let f(n) and g(n) be functions, where n is a positive integer.
• We write f(n) = O(g(n)) if and only if there exists a positive constant c and positive
integer n0 satisfying 0 <= f(n) <= cg(n) for all n >= n0.

▪ Big - Oh notation describes the worst case of an algorithm time


complexity.
Big - Omega (Ω): Lower bound
• Definition: Let f(n) and g(n) be functions, where n is a positive integer.
• If there exist positive constants c and n0 such that 0 <= cg(n) <= f(n) for all n >= n0

▪ Big - Omega notation describes the best case of an algorithm time


complexity.
Big - Theta (Θ)
• Definition: Let f(n) and g(n) be functions, where n is a positive
integer.
Θ(g(n))= f(n) : there exist positive constants c1, c2 and n0 such that
0 ≤ c1∗g(n) ≤f(n) ≤ c2∗g(n) for all n>n0

▪ Big -Theta notation describes the average case of an algorithm time


complexity.
Relations Between O, Ω, Θ

Comp 122

You might also like