6.854J/18.415J Advanced Algorithms - MIT

MIT

This course is a first-year graduate course in algorithms. Emphasis is placed on fundamental algorithms and advanced methods of algorithmic design, analysis, and implementation. Techniques to be covered include amortization, randomization, fingerprinting, word-level parallelism, bit scaling, dynamic programming, network flow, linear programming, fixed-parameter algorithms, and approximation algorithms. Domains include string algorithms, network optimization, parallel algorithms, computational geometry, online algorithms, external memory, cache, and streaming algorithms, and data structures. The need for efficient algorithms arises in nearly every area of computer science. But the type of problem to be solved, the notion of what algorithms are "efficient, and even the model of computation can vary widely from area to area. In this second class in algorithms, we will survey many of the techniques that apply broadly in the design of efficient algorithms, and study their application in a wide range of application domains and computational models. The goal is for the class to be broad rather than deep. Our plan is to touch upon the following areas. This is a tentative list of topics that might be covered in the class; we will select material adaptively based on the background, interests, and rate of progress of the students.

University CoursesAlgorithm

Introduction

This course is a first-year graduate course in algorithms. Emphasis is placed on fundamental algorithms and advanced methods of algorithmic design, analysis, and implementation.

screenshot

Highlights

  • Covers techniques such as amortization, randomization, fingerprinting, word-level parallelism, bit scaling, dynamic programming, network flow, linear programming, fixed-parameter algorithms, and approximation algorithms
  • Explores domains including string algorithms, network optimization, parallel algorithms, computational geometry, online algorithms, external memory, cache, and streaming algorithms, and data structures

Recommendation

This course is recommended for graduate students in computer science or related fields who are interested in a comprehensive survey of advanced algorithmic techniques and their applications across a wide range of domains.

How GetVM Works

Learn by Doing from Your Browser Sidebar

Access from Browser Sidebar

Access from Browser Sidebar

Simply install the browser extension and click to launch GetVM directly from your sidebar.

Select Your Playground

Select Your Playground

Choose your OS, IDE, or app from our playground library and launch it instantly.

Learn and Practice Side-by-Side

Learn and Practice Side-by-Side

Practice within the VM while following tutorials or videos side-by-side. Save your work with Pro for easy continuity.

Explore Similar Hands-on Tutorials

A Field Guide To Genetic Programming

30
Technical TutorialsAlgorithm
Comprehensive guide to genetic programming, covering evolutionary algorithms, computational biology, and advanced programming techniques. Valuable resource for computer scientists, biologists, and researchers.

Algorithms | Fundamental Concepts & Techniques

19
Technical TutorialsAlgorithmData Structures
Comprehensive guide to the fundamental concepts and techniques in the field of algorithms, covering discrete mathematics, data structures, and algorithm analysis.

Algorithms and Data Structures - With Applications to Graphics and Geometry

27
Technical TutorialsAlgorithmData Structures
Explore algorithms, data structures, and their practical applications in graphics and geometry. Suitable for beginners and experienced learners.

Data Structures | Algorithms | Efficient Software Systems

16
Technical TutorialsAlgorithmData Structures
Comprehensive guide to data structures and algorithms, covering arrays, linked lists, stacks, queues, trees, and more. Ideal for students, developers, and professionals seeking to build efficient software systems.

Data Structures (Into Java)

9
Technical TutorialsAlgorithmData StructuresJava
Comprehensive guide to understanding and implementing data structures using Java, covering arrays, linked lists, stacks, queues, trees, and more.

Data Structures and Algorithm Analysis in C++

7
Technical TutorialsAlgorithmC++
Comprehensive guide to data structures, algorithms, and problem-solving using C++. Suitable for students and professionals interested in algorithmic problem-solving.

Elementary Algorithms | Fundamental Algorithms and Data Structures

27
Technical TutorialsAlgorithmData Structures
Comprehensive introduction to fundamental algorithms and data structures, including sorting, searching, and algorithm design. Suitable for beginners and professionals.

Essential Algorithms | Comprehensive Guide to Algorithms and Data Structures

25
Technical TutorialsAlgorithmData Structures
Enhance your programming and problem-solving skills with Essential Algorithms, a comprehensive guide covering essential concepts for beginners and advanced programmers.

Learning Algorithm | Algorithms, Data Structures, Problem-Solving

26
Technical TutorialsAlgorithmData Structures
Explore a wide range of algorithms, from fundamental data structures to advanced techniques like dynamic programming and graph algorithms. Gain practical knowledge for software engineering and problem-solving.