Academics
  /  
Courses
  /  
Descriptions
COMP_SCI 396, 496: Approximation Algorithms


VIEW ALL COURSE TIMES AND SESSIONS

Prerequisites

COMP_SCI 212 and COMP_SCI 336 (or similar courses)

Description

This course studies approximation algorithms – algorithms that are used for solving hard optimization problems. Such algorithms find approximate (slightly suboptimal) solutions to optimization problems in polynomial time. Unlike heuristics, approximation algorithms have provable performance guarantees: they have bounds on the running time and on the quality of the obtained solutions. In this course, we will introduce various algorithmic techniques used for solving optimization problems such as greedy algorithms, local search, dynamic programming, linear programming (LP), semidefinite programming (SDP), LP duality, randomized rounding, and primal-dual analysis.

The course assumes background in basic probability theory and discrete mathematics. Key mathematical concepts will be reviewed before they are used.

RECOMMENDED TEXTS:

COURSE INSTRUCTOR: Prof. Konstantin Makarychev