Description
In this course you will learn several fundamental principles of advanced algorithm design. You'll learn the greedy algorithm design paradigm, with applications to computing good network backbones (i.e., spanning trees) and good codes for data compression. You'll learn the tricky yet widely applicable dynamic programming algorithm design paradigm, with applications to routing in the Internet and sequencing genome fragments. You'll learn what NPcompleteness and the famous "P vs. NP" problem mean for the algorithm designer. Finally, we'll study several strategies for dealing with hard (i.e., NPcomplete problems), including the design and analysis of heuristics. Learn how shortestpath algorithms from the 1950's (i.e., preARPANET!) govern the way that your Internet traffic gets routed today; why efficient algorithms are fundamental to modern genomics; and how to make a million bucks in prize money by "just" solving a math problem!Course Syllabus
Weeks 1 and 2: The greedy algorithm design paradigm. Applications to optimal caching and scheduling. Minimum spanning trees and applications to clustering. The unionfind data structure. Optimal data compression.
Weeks 3 and 4: The dynamic programming design paradigm. Applications to the knapsack problem, sequence alignment, shortestpath routing, and optimal search trees.
Weeks 5 and 6: Intractable problems and what to do about them. NPcompleteness and the P vs. NP question. Solvable special cases. Heuristics with provable performance guarantees. Local search. Exponentialtime algorithms that beat bruteforce search.
Recommended Background
How to program in at least one programming language (like C, Java, or Python); and familiarity with proofs, including proofs by induction and by contradiction. At Stanford, a version of this course is taken by sophomore, junior, and seniorlevel computer science majors. The course assumes familiarity with some of the topics from Algo 1  especially asymptotic analysis, basic data structures, and basic graph algorithms.Suggested Readings
No specific textbook is required for the course. Much of the course material is covered by the wellknown textbooks on algorithms, and the student is encouraged to consult their favorite for additional information.
Course Format
The class will consist of lecture videos, generally between 10 and 15 minutes in length. These usually have integrated quiz questions. There will also be standalone homeworks and programming assignments that are not part of video lectures, and a final exam.FAQ
 Will I get a statement of accomplishment after completing this class? Yes. Students who successfully complete the class will receive a statement of accomplishment signed by the instructor.
 What is the format of the class? The class consists of lecture videos, which are broken into small chunks, usually between eight and twelve minutes each. Some of these may contain integrated quiz questions. There will also be standalone quizzes that are not part of video lectures. There will be approximately two hours worth of video content per week.
 What should I know to take this class? How to program in at least one programming language (like C, Java, or Python); familiarity with proofs, including proofs by induction and by contradiction; and some discrete probability, like how to compute the probability that a poker hand is a full house. At Stanford, a version of this course is taken by sophomore, junior, and seniorlevel computer science majors. While Part 2 is designed for students who have already taken Part 1, some students have successfully completed Part 2 without taking Part 1.
Delivery Option: 
Online

Online Course  Free 
This course may not currently be available to learners in some states and territories.