About this Course

This class is offered as CS6505 at Georgia Tech where it is a part of the Online Masters Degree (OMS). Taking this course here will not earn credit towards the OMS degree.

In this course, we will ask the big questions, “What is a computer? What are the limits of computation? Are there problems that no computer will ever solve? Are there problems that can’t be solved quickly? What kinds of problems can we solve efficiently and how do we go about developing these algorithms?” Understanding the power and limitations of algorithms helps us develop the tools to make real-world computers smarter, faster and safer.

Course Cost
Free
Timeline
Approx. 0
Skill Level
Advanced
Included in Course
  • Rich Learning Content

  • Interactive Quizzes

  • Taught by Industry Pros

  • Self-Paced Learning

  • Student Support Community

Join the Path to Greatness

This free course is your first step towards a new career with the Machine Learning Engineer Nanodegree Program.

Free Course

Computability, Complexity & Algorithms

by Georgia Institute of Technology

Enhance your skill set and boost your hirability through innovative, independent learning.

Icon steps 54aa753742d05d598baf005f2bb1b5bb6339a7d544b84089a1eee6acd5a8543d

Course Leads

  • Charles Brubaker
    Charles Brubaker

    Instructor

  • Lance Fortnow
    Lance Fortnow

    Instructor

  • Hariharan Venkateswaran
    Hariharan Venkateswaran

    Instructor

What You Will Learn

Lesson 1

Computability

  • Languages & Countability
  • Turing Machines
  • The Church-Turing Thesis
Lesson 1

Computability

  • Languages & Countability
  • Turing Machines
  • The Church-Turing Thesis
Lesson 2

Complexity

  • P and NP
  • NP-Complete Problems
  • The Golden Ticket
Lesson 2

Complexity

  • P and NP
  • NP-Complete Problems
  • The Golden Ticket
Lesson 3

Algorithms

  • Dynamic Programming
  • Fast Fourier Transform
  • Maximum Flow
Lesson 3

Algorithms

  • Dynamic Programming
  • Fast Fourier Transform
  • Maximum Flow

Prerequisites and Requirements

Students are expected to have a solid grasp of the basics of discrete mathematics. Discrete Mathematics and Its Applications by Ken Rosen provides an excellent background for this course.

If you answer “no” to any of the following questions, it may be beneficial to acquire background knowledge concurrently or prior to taking the course.

  1. Can you show that the sum of the first n numbers is n(n+1)/2? Can you give the proof as an induction on n?
  2. Can you give an O(n log n) algorithm for sorting n numbers?
  3. Can you describe the difference between breadth-first and depth-first search?
  4. Given an nxn matrix A and an n-dimensional vector b, can you give a polynomial-time algorithm to find a vector x such that Ax=b?

See the Technology Requirements for using Udacity.

Why Take This Course

You will learn a wealth of tools and techniques that will help you recognize when problems you encounter in the real-world are intractable and when there an efficient solution. This can save you countless hours that otherwise would have been spent on a fruitless endeavor or in re-inventing the wheel.

What do I get?
  • Instructor videos
  • Learn by doing exercises
  • Taught by industry professionals
Icon globe e82eae5d45465aba4fbe4bb746905ce55dc3324f310b79c60e4a20089057d347

Udacity 现已提供中文版本! A Udacity tem uma página em português para você! There's a local version of Udacity for you! Sprechen Sie Deutsch?

Besuchen Sie de.udacity.com und entdecken Sie lokale Angebote, unsere Partnerunternehmen und Udacitys deutschsprachigen Blog.

前往优达学城中文网站 Ir para a página brasileira Go to Indian Site Icon flag de deedb1a7a695700236cb6ef4204ddbede5d197dab9b47716c87a0b4d5d9fc325 Zu de.udacity.com continue in English