Professional Documents
Culture Documents
……………………………………………………………………………………………………………………………….
1. Algorithm Definition
An algorithm is a finite set of instructions that, if followed, accomplishes a particular task. In addition, all
algorithms must satisfy the following criteria:
Finiteness: If we trace out the instructions of an algorithm, then for all cases, the algorithm terminates after a
finite number of steps.
Effectiveness: Every instruction must be vey basic so that it can be carried out, in principle, b a person using
only pencil and paper. It is not enough that each operation be definite, it also must be feasible.
1. How to devise algorithms: Techniques–Divide & Conquer, Branch and Bound, Dynamic Programming
The purpose of the validation is to assure us that this algorithm will work correctly independently of the issues
concerning the programming language it will eventually be written in.
analysis algorithms or performance analysis refers to the task of determining how much computing time and
storage time an algorithm required.
• Debugging - Debugging is the process of executing programs on sample data sets to determine whether
faulty results occur and, if so, to correct them.
• Profiling or performance measurement is the process of executing a correct program on data sets and
measuring the time and space it takes to compute the results.
We represent algorithm using a pseudo language that is a combination of the constructs of a programming
language together with informal English statements.
1. Natural language like English: When this way is choused care should be taken, we should ensure that each &
every statement is definite.
2. Graphic representation called flowchart: This method will work well when the algorithm is small& simple.
3. Pseudo-code Method: In this method, we should typically describe algorithms as program, which resembles
language like Pascal & algol.
1. Pseudo-Code Conventions:
3. An identifier begins with a letter. The data types of variables are not explicitly declared.
Node. Record
node * link;
Here link is a pointer to the record type node. Individual data items of a record can be accessed with → and
period.
<Variable>:= <expression>;
While Loop:
<statement-1>
<statement-n>
For Loop:
<statement-1>
<statement-n>
repeat-until:
repeat
<statement-1>
<statement-n>
until<condition>
Case statement:
Case
: <condition-1> : <statement-1>
3 © www.tutorialtpoint.net Pepared by D.Venkata Reddy M.Tech(Ph.D), UGC NET, AP SET Qualififed
.
: <condition-n>: <statement-n>
: else: <statement-n+1>
9. Input and output are done using the instructions read & write.
10. There is only one type of procedure: Algorithm, the heading takes the form,
Example:
3.{
4. for I: =1 to n do
5. {
6. j: =I;
7. for k: =i+1 to n do
8. if (a[k]<a[j])
9. t: =a[I];
11. a[j]:=t;
12. }
13. }
Time Complexity:
The time needed by an algorithm expressed as a function of the size of a problem is called the time complexity
of the algorithm. The time complexity of a program is the amount of computer time it needs to run to
completion.
The limiting behavior of the complexity as size increases is called the asymptotic time complexity. It is the
asymptotic complexity of an algorithm, which ultimately determines the size of problems that can be solved by
the algorithm.
When solving a problem, we are faced with a choice among algorithms. The basis for this can be any one of the
following:
ii. We would like an algorithm that makes efficient use of the computer’s resources, especially, one that runs as
fast as possible.
2. The quality of code generated by the compiler used to create the object program.
3. The nature and speed of the instructions on the machine used to execute the program,
Space Complexity:
The space complexity of a program is the amount of memory it needs to run to completion. The space need by
a program has the following components:
Environment stack space: The environment stack is used to save information needed to resume execution of
partially completed functions.
Instruction Space: Instruction space is the space needed to store the compiled version of the program instructions.
The amount of instructions space that is needed depends on factors such as:
The space requirement s(p) of any algorithm p may therefore be written as,
Example 2:
Algorithm sum(a,n)
s=0.0;
for I=1 to n do
s= s+a[I];
return s;
• The problem instances for this algorithm are characterized by n, the number of elements to be summed.
The space needed by ‘n’ is one word, since it is of type integer.
• The space needed by ‘a’ is the space needed by variables of type array of floating-point numbers. This is
at least ‘n’ words, since ‘a’ must be large enough to hold the ‘n’ elements to be summed.
• So, we obtain Sp(sum(n)>=(n+s))[ n for a[ ], one each for n, I a& s]
Complexity of Algorithms
The complexity of an algorithm M is the function f(n) which gives the running time and/or storage space
requirement of the algorithm in terms of the size ‘n’ of the input data. Mostly, the storage space required by
an algorithm is simply a multiple of the data size ‘n’. Complexity shall refer to the running time of the
algorithm.
The function f(n), gives the running time of an algorithm, depends not only on the size ‘n’ of the input data
but also on the particular data. The complexity function f(n) for certain cases is:
1. Best Case: The minimum possible value of f(n) is called the best case.
3. Worst Case: The maximum value of f(n) for any key possible input
When there are multiple alternative algorithms to solve a problem, we analyze them and pick the one which is
best suitable for our requirements. The formal definition is as follows...
Performance of an algorithm means predicting the resources which are required to an algorithm to perform its
task.
That means when we have multiple algorithms to solve a problem, we need to select a suitable algorithm to
solve that problem.
We compare algorithms with each other which are solving the same problem, to select the best algorithm. To
compare algorithms, we use a set of parameters or set of elements like memory required by that algorithm,
the execution speed of that algorithm, easy to understand, easy to implement, etc.,
1. Whether that algorithm is providing the exact solution for the problem?
When we want to analyse an algorithm, we consider only the space and time required by that particular
algorithm and we ignore all the remaining elements.
Based on this information, performance analysis of an algorithm can also be defined as follows...
Performance analysis of an algorithm is the process of calculating space and time required by that algorithm.
1. Space required to complete the task of that algorithm (Space Complexity). It includes program space
and data space
Whenever we want to perform analysis of an algorithm, we need to calculate the complexity of that
algorithm. But when we calculate the complexity of an algorithm it does not provide the exact amount of
resource required. So instead of taking the exact amount of resource, we represent that complexity in a
general form (Notation) which produces the basic nature of that algorithm. We use that general form
(Notation) for analysis process.
Note - In asymptotic notation, when we want to represent the complexity of an algorithm, we use only the
most significant terms in the complexity of that algorithm and ignore least significant terms in the complexity
of that algorithm (Here complexity can be Space Complexity or Time Complexity).
• Algorithm 1: 5n2 + 2n + 1
• Algorithm 2: 10n2 + 8n + 3
Generally, when we analyze an algorithm, we consider the time complexity for larger values of input data (i.e.
'n' value). In above two-time complexities, for larger value of 'n' the term '2n + 1' in algorithm 1 has least
significance than the term '5n2', and the term '8n + 3' in algorithm 2 has least significance than the term '10n2'.
Here, for larger value of 'n' the value of most significant terms (5n2 and 10n2 ) is very larger than the value of
least significant terms ( 2n + 1 and 8n + 3 ). So, for larger value of 'n' we ignore the least significant terms to
represent overall time required by an algorithm. In asymptotic notation, we use only the most significant
terms to represent the time complexity of an algorithm.
Majorly, we use THREE types of Asymptotic Notations and those are as follows...
1. Big - Oh (O)
Big - Oh notation is used to define the upper bound of an algorithm in terms of Time Complexity.
That means Big - Oh notation always indicates the maximum time required by an algorithm for all input
values. That means Big - Oh notation describes the worst case of an algorithm time complexity.
Big - Oh Notation can be defined as follows...
Consider function f(n) as time complexity of an algorithm and g(n) is the most significant term. If f(n) <= C g(n) for all n
>= n0, C > 0 and n0 >= 1. Then we can represent f(n) as O(g(n)).
f(n) = O(g(n))
Consider the following graph drawn for the values of f(n) and C g(n) for input (n) value on X-Axis and time
required is on Y-Axis
Example
Big - Omega notation is used to define the lower bound of an algorithm in terms of Time Complexity.
That means Big-Omega notation always indicates the minimum time required by an algorithm for all input
values. That means Big-Omega notation describes the best case of an algorithm time complexity.
Big - Omega Notation can be defined as follows...
Consider function f(n) as time complexity of an algorithm and g(n) is the most significant term. If f(n) >= C
g(n) for all n >= n0, C > 0 and n0 >= 1. Then we can represent f(n) as Ω(g(n)).
f(n) = Ω(g(n))
Consider the following graph drawn for the values of f(n) and C g(n) for input (n) value on X-Axis and time
required is on Y-Axis
Example
Big - Theta notation is used to define the average bound of an algorithm in terms of Time Complexity.
That means Big - Theta notation always indicates the average time required by an algorithm for all input
values. That means Big - Theta notation describes the average case of an algorithm time complexity.
Big - Theta Notation can be defined as follows...
Consider function f(n) as time complexity of an algorithm and g(n) is the most significant term. If C1 g(n) <=
f(n) <= C2 g(n) for all n >= n0, C1 > 0, C2 > 0 and n0 >= 1. Then we can represent f(n) as Θ(g(n)).
f(n) = Θ(g(n))
Consider the following graph drawn for the values of f(n) and C g(n) for input (n) value on X-Axis and time
required is on Y-Axis
Example
7. Randomized Algorithms
An algorithm that uses random numbers to decide what to do next anywhere in its logic is called Randomized
Algorithm. For example, in Randomized Quick Sort, we use a random number to pick the next pivot (or we
randomly shuffle the array). Typically, this randomness is used to reduce time complexity or space complexity
in other standard algorithms.
1. Las Vegas
2. Monte Carlo
Las Vegas algorithms, always output the correct answer, but their running time may vary. The most prime
examples of such algorithms are quicksort and quick select.
One subclass is random testing. Such algorithms are the Miller-Rabin primality test, Freivalds' algorithm and
checking if two polynomials are equal. These algorithms base themselves on the fact that there are many
witnesses (at least half) if the answer is no, so after performing the test a few times, we can be fairly sure that
we have the correct answer.
The other subclass is optimization Las Vegas algorithms. Such examples are Karger’s min-cut algorithm and the
linear MST algorithm.
Heuristic algorithms. The most known is probably Simulated Annealing. The second most well-known is the
family of Genetic Algorithms. There is extensive bibliography for heuristic algorithms such as Iterated Local
Search (ILS), GRASP, Ant Colony Optimization (ACO), Cuckoo Search, Harmony Search, Artificial Bee Colony
(ABC), Firefly Search and the list never ends.
Another subclass of randomized algorithms is randomized rounding of linear programming relaxation. Many
problems (Min cut, Set Cover, Vertex Cover, TSP) can be expressed as an Integer Programming problem. In
order to get a solution, we formulate the relaxed Linear Programming problem, solve it and perform
randomized rounding on the solution to obtain the final solution.
UNIT-I Questions
6. Define Time and Space Complexity, and calculate the time space complexity for multiplication of two
matrices.
7. Write different pseudo code conventions used to represent an algorithm
8. What do you mean by performance analysis? Give the algorithm for matrix multiplication and find the
time complexity using step–count method.
9. What are the different mathematical notations used for algorithm analysis? Explain them. (Ans:
asymptotic notations)
10. Give the algorithm for transpose of a matrix of size mxn and determine the time complexity of the
algorithm by frequency – count method.
The step count method is one of the method to analyze the algorithm. In this method, we count number of
times one instruction is executing. From that we will try to find the complexity of the algorithm.
Time and space complexity are calculated using step count method. Some basic assumptions are;
– There is no count for { and } .
– Each basic statement like ’assignment’ and ’return’ have a count of 1.
– If a basic statement is iterated, then multiply by the number of times the loop is run.
– The loop statement is iterated n times, it has a count of (n + 1). Here the loop runs n times for the true case
and a check is performed for the loop exit (the false condition), hence the additional 1 in the count.
Basically, frequency count is very simple to understand. It means, the number of times the statement is
executed in the program.
Program Segment A:
x = x+2
Program Segment B:
for k =1 to n do
x = x+2
end
Program Segment C:
for j= 1 to n do
for x = 1 to n do
x = x+2
end
end
Now, let us estimate the frequency count of the statement x = x+2 occurring in the following three program
statements.(A, B, C)
The frequency count of the statement in the program segment A is 1.(It gets executed once)
In the program segment B, the frequency count of the statement is n, since the for loop in which the statement
is embedded executes n(n>=1) times.
In the program segment C, the statement is executed n^2(n>=1) times, since the statement is embedded in a
nested for loop, executing n times each.