University of Colorado Boulder
Foundations of Data Structures and Algorithms Specialization
University of Colorado Boulder

Foundations of Data Structures and Algorithms Specialization

Access provided by Marlabs

43,891 already enrolled

Get in-depth knowledge of a subject
4.7

(504 reviews)

Advanced level

Recommended experience

6 months to complete
at 10 hours a week
Flexible schedule
Learn at your own pace
Get in-depth knowledge of a subject
4.7

(504 reviews)

Advanced level

Recommended experience

6 months to complete
at 10 hours a week
Flexible schedule
Learn at your own pace

What you'll learn

  • Organize, store and process data efficiently using sophisticated data structures and algorithms

  • Design algorithms and analyze their complexity in terms of running time and space usage

  • Create applications that are supported by highly efficient algorithms and data structures for the task at hand

Details to know

Shareable certificate

Add to your LinkedIn profile

Taught in English

See how employees at top companies are mastering in-demand skills

 logos of Petrobras, TATA, Danone, Capgemini, P&G and L'Oreal

Advance your subject-matter expertise

  • Learn in-demand skills from university and industry experts
  • Master a subject or tool with hands-on projects
  • Develop a deep understanding of key concepts
  • Earn a career certificate from University of Colorado Boulder

Specialization - 5 course series

What you'll learn

  • Explain fundamental concepts for algorithmic searching and sorting

  • Describe heap data structures and analyze heap components, such as arrays and priority queues

  • Design basic algorithms to implement sorting, selection, and hash functions in heap data structures

Skills you'll gain

Category: Algorithms
Category: Data Structures
Category: Analysis
Category: Probability & Statistics
Category: Big Data
Category: Computational Thinking
Category: Computer Programming
Category: Python Programming
Category: Pseudocode
Trees and Graphs: Basics

Trees and Graphs: Basics

Course 234 hours

What you'll learn

  • Define basic tree data structures and identify algorithmic functions associated with them

  • Execute traversals and create graphs within a binary search tree structure

  • Describe strongly connected components in graphs

Skills you'll gain

Category: Graph Theory
Category: Algorithms
Category: Data Structures
Category: Python Programming
Category: Computational Thinking
Category: Tree Maps
Category: Network Analysis

What you'll learn

  • Describe basic algorithm design techniques

  • Create divide and conquer, dynamic programming, and greedy algorithms

  • Understand intractable problems, P vs NP and the use of integer programming solvers to tackle some of these problems

Skills you'll gain

Category: Algorithms
Category: Theoretical Computer Science
Category: Programming Principles
Category: Advanced Mathematics
Category: Analysis
Category: Mathematical Theory & Analysis
Category: Computer Programming
Category: Program Development
Category: Computer Science
Category: Python Programming
Category: Data Analysis
Category: Data Structures
Category: Computational Thinking

What you'll learn

  • Formulate linear and integer programming problems for solving commonly encountered optimization problems.

  • Develop a basic understanding of how linear and integer programming problems are solved.

  • Understand how approximation algorithms compute solutions that are guaranteed to be within some constant factor of the optimal solution

Skills you'll gain

Category: Algorithms
Category: Python Programming
Category: Theoretical Computer Science
Category: Graph Theory
Category: Combinatorics
Category: Mathematical Modeling
Category: Operations Research
Category: Computational Thinking
Category: Applied Mathematics

What you'll learn

  • Explore how basic number-theoretic concepts are used to build the RSA crypto-system.

  • Examine the foundations of quantum computation and its basic building blocks.

  • Explore how quantum computers can be used to break the RSA cryptosystem.

  • Explore the differences between classical and quantum algorithms.

Skills you'll gain

Category: Algorithms
Category: Cryptography
Category: Encryption
Category: Arithmetic
Category: Public Key Cryptography Standards (PKCS)
Category: Data Structures
Category: Linear Algebra
Category: Python Programming
Category: Computational Thinking
Category: Data Storage Technologies
Category: Computer Science
Category: Theoretical Computer Science

Earn a career certificate

Add this credential to your LinkedIn profile, resume, or CV. Share it on social media and in your performance review.

Build toward a degree

This Specialization is part of the following degree program(s) offered by University of Colorado Boulder. If you are admitted and enroll, your completed coursework may count toward your degree learning and your progress can transfer with you.¹

 

Instructor

Sriram Sankaranarayanan
University of Colorado Boulder
5 Courses91,416 learners

Offered by

Why people choose Coursera for their career

Felipe M.
Learner since 2018
"To be able to take courses at my own pace and rhythm has been an amazing experience. I can learn whenever it fits my schedule and mood."
Jennifer J.
Learner since 2020
"I directly applied the concepts and skills I learned from my courses to an exciting new project at work."
Larry W.
Learner since 2021
"When I need courses on topics that my university doesn't offer, Coursera is one of the best places to go."
Chaitanya A.
"Learning isn't just about being better at your job: it's so much more than that. Coursera allows me to learn without limits."