First week schedule: No class on Aug 1 and 4th. Replacement class on Aug 6 10-1pm.

This course is an advanced form of an introductory algorithms course, and is meant to have a thorough grounding in core Algorithms required for pursuing PG degree in Computer Science. The course covers topics such as asymptotic notation, recurrence relation, graph algorithms, heaps, dynamic programming, greedy algorithms, divide and conquer, NP-completeness where the UG contents of each topic is first reviewed in a fast-paced manner, and is followed by some advanced content.


  • Undergraduate Algorithms course
Open only to M.Tech. and Ph.D. students in Monsoon 2016 semester (recommended for students with inadequate background in Algorithms).

Post Conditions

1. The student is able to design and analyse algorithms using techniques like divide and conquer, greedy and dynamic programming.
2. The student is able to use standard data structures like heaps, trees and graphs for designing algorithms.
3. The student is able to prove NP-completeness of problems using reductions.
4. The student is familiar with modern techniques to handle intractable problems like randomization, approximation, backtracking search.


Monday and Thursday 11:30-1pm (C12).