Approximation Algorithms Part I
Offered By: École normale supérieure via Coursera
Course Description
Overview
Approximation algorithms, Part I
How efficiently can you pack objects into a minimum number of boxes? How well can you cluster nodes so as to cheaply separate a network into components around a few centers? These are examples of NP-hard combinatorial optimization problems. It is most likely impossible to solve such problems efficiently, so our aim is to give an approximate solution that can be computed in polynomial time and that at the same time has provable guarantees on its cost relative to the optimum.
This course assumes knowledge of a standard undergraduate Algorithms course, and particularly emphasizes algorithms that can be designed using linear programming, a favorite and amazingly successful technique in this area. By taking this course, you will be exposed to a range of problems at the foundations of theoretical computer science, and to powerful design and analysis techniques. Upon completion, you will be able to recognize, when faced with a new combinatorial optimization problem, whether it is close to one of a few known basic problems, and will be able to design linear programming relaxations and use randomized rounding to attempt to solve your own problem. The course content and in particular the homework is of a theoretical nature without any programming assignments.
This is the first of a two-part course on Approximation Algorithms.
Syllabus
- Vertex cover and Linear Programming
- We introduce the course topic by a typical example of a basic problem, called Vertex Cover, for which we will design and analyze a state-of-the-art approximation algorithm using two basic techniques, called Linear Programming Relaxation and Rounding. It is a simple, elementary application of powerful techniques.
- Knapsack and Rounding
- This module shows the power of rounding by using it to design a near-optimal solution to another basic problem: the Knapsack problem.
- Bin Packing, Linear Programming and Rounding
- This module shows the sophistication of rounding by using a clever variant for another basic problem: bin packing. (This is a more advanced module.)
- Set Cover and Randomized Rounding
- This module introduces a simple and powerful variant of rounding, based on probability: randomized rounding. Its power is applied to another basic problem, the Set Cover problem.
- Multiway Cut and Randomized Rounding
- This module deepens the understanding of randomized rounding by developing a sophisticated variant and applying it to another basic problem, the Multiway Cut problem. (This is a more advanced module.)
Taught by
Claire Mathieu
Related Courses
Greedy Algorithms, Minimum Spanning Trees, and Dynamic ProgrammingStanford University via Coursera Introduction to Computational Thinking and Data Science
Massachusetts Institute of Technology via edX Recursion, Backtracking and Dynamic Programming in Python
Udemy