Analysis and Design of Algorithms
Analysis and Design of Algorithms
Prerequisite:
1. Programming (C or C++)
2. Data and file structure
Objectives:
1. Analyze the asymptotic performance of algorithms.
2. Demonstrate a familiarity with major algorithm design techniques.
3. Apply important algorithmic design paradigms and methods of analysis.
4. Solve simple to moderately difficult algorithmic problems arising in applications.
5. Able to demonstrate the hardness of simple NP-complete problems.
Teaching and Examination Scheme:
4 0 2 6 5 40 60 20 30 150
Content:
Dynamic Programming:
Introduction, The Principle of Optimality, Problem Solving
using Dynamic Programming – Calculating the Binomial 15
4 7
Coefficient, Making Change Problem, Assembly
Line-Scheduling, Knapsack problem, All Points Shortest path,
Matrix chain multiplication, Longest Common Subsequence.
Greedy Algorithm
General Characteristics of greedy algorithms, Problem solving
using Greedy Algorithm - Activity selection problem,
5 Elements of Greedy Strategy, Minimum Spanning trees 7 15
(Kruskal’s algorithm, Prim’s algorithm), Graphs: Shortest
paths, The Knapsack Problem, Job Scheduling Problem,
Huffman code.
Exploring Graphs:
An introduction using graphs and games, Undirected Graph, 10
6 6
Directed Graph, Traversing Graphs, Depth First Search,
Breath First Search, Topological sort, Connected components
8 String Matching: 4 5
Introduction, The naive string matching algorithm, The
Rabin-Karp algorithm, String Matching with finite automata,
The Knuth-Morris-Pratt algorithm.
Introduction to NP-Completeness:
The class P and NP, Polynomial reduction, NP- Completeness
Problem, NP-Hard Problems. Travelling Salesman problem, 7
9 5
Hamiltonian problem, Approximation algorithms,
Randomized algorithms, Class of problems beyond NP – P
SPACE
Course Outcome:
1. The course includes a laboratory, where students get the opportunity to practically apply
the theoretical knowledge they have acquired in the lectures.
2. Lectures with attractive PowerPoint presentations
3. Different experiments shall be carried out during the practical sessions.
● List of Experiments/Tutorials:
1. Implementation and Time analysis of sorting algorithms.
Bubble sort, Selection sort, Insertion sort, Merge sort and Quicksort
2. Implementation and Time analysis of linear and binary search algorithm.
3. Implementation of max-heap sort algorithm
4. Implementation and Time analysis of factorial program using iterative and
recursive method
5. Implementation of a knapsack problem using dynamic programming.
6. Implementation of chain matrix multiplication using dynamic programming.
7. Implementation of making a change problem using dynamic programming
8. Implementation of a knapsack problem using greedy algorithm
9. Implementation of Graph and Searching (DFS and BFS).
10. Implement prim’s algorithm
11. Implement kruskal’s algorithm.
12. Implement LCS problem.
● Books Recommended:
1. Introduction to Algorithms, Thomas H. Cormen, Charles E. Leiserson, Ronald L.
Rivestand Clifford Stein, PHI.
2. Fundamentals of Algorithms – E. Horowitz et al.
3. Fundamental of Algorithms by Gills Brassard, Paul Bratley, PHI.
4. Introduction to Design and Analysis of Algorithms, Anany Levitin, Pearson.
5. Foundations of Algorithms, Shailesh R Sathe, Penram
6. Design and Analysis of Algorithms, Dave and Dave, Pearson.