University of California San Diego
Data Structures and Algorithms Specialization
University of California San Diego

Data Structures and Algorithms Specialization

Master Algorithmic Programming Techniques. Advance your Software Engineering or Data Science Career by Learning Algorithms through Programming and Puzzle Solving. Ace coding interviews by implementing each algorithmic challenge in this Specialization. Apply the newly-learned algorithmic techniques to real-life problems, such as analyzing a huge social network or sequencing a genome of a deadly pathogen.

Michael Levin
Daniel M Kane
Pavel  Pevzner

Instructors: Michael Levin

346,018 already enrolled

Included withCoursera Plus

Get in-depth knowledge of a subject
4.6

(13,214 reviews)

Intermediate level

Recommended experience

5 months
at 10 hours a week
Flexible schedule
Learn at your own pace
Get in-depth knowledge of a subject
4.6

(13,214 reviews)

Intermediate level

Recommended experience

5 months
at 10 hours a week
Flexible schedule
Learn at your own pace

What you'll learn

  • Play with 50 algorithmic puzzles on your smartphone to develop your algorithmic intuition!  Apply algorithmic techniques (greedy algorithms, binary search, dynamic programming, etc.) and data structures (stacks, queues, trees, graphs, etc.) to solve 100 programming challenges that often appear at interviews at high-tech companies. Get an instant feedback on whether your solution is correct.

  • Apply the newly learned algorithms to solve real-world challenges: navigating in a Big Network  or assembling a genome of a deadly pathogen from millions of short substrings of its DNA.

  • Learn exactly the same material as undergraduate students in “Algorithms 101” at top universities and more! We are excited that students from various parts of the world are now studying our online materials in the Algorithms 101 classes at their universities. Here is a quote from the website of Professor Sauleh EetemadiOpens in a new tab from Iran University of Science and Technology: “After examining syllabus and course material from top universities including StanfordOpens in a new tabPrincetonOpens in a new tab and MITOpens in a new tab we have chosen to follow the Data Structures and Algorithms SpecializationOpens in a new tab from UCSD...due to excellent course material and its practical approach.”

  • If you decide to venture beyond Algorithms 101, try to solve more complex programming challenges (flows in networks, linear programming, streaming algorithms, etc.) and complete an equivalent of a graduate course in algorithms!

Details to know

Earn a career certificate

Add to your LinkedIn profile

Taught in English

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

Placeholder

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 California San Diego
Placeholder
Placeholder

Earn a career certificate

Add this credential to your LinkedIn profile, resume, or CV

Share it on social media and in your performance review

Placeholder

Specialization - 6 course series

Algorithmic Toolbox

Course 140 hours4.6 (12,448 ratings)

What you'll learn

  • Essential algorithmic techniques

  • Design efficient algorithms

  • Practice solving algorithmic interview problems

  • Implement efficient and reliable solutions

Skills you'll gain

Category: Python Programming
Category: Linear Programming (LP)
Category: Np-Completeness
Category: Dynamic Programming

Data Structures

Course 222 hours4.6 (5,459 ratings)

What you'll learn

Skills you'll gain

Category: Graph Theory
Category: Graphs
Category: Graph Algorithms

Algorithms on Graphs

Course 354 hours4.7 (2,257 ratings)

What you'll learn

Skills you'll gain

Category: Data Structure
Category: Algorithms
Category: Algorithm Design
Category: String (Computer Science)

Algorithms on Strings

Course 418 hours4.5 (1,084 ratings)

What you'll learn

Skills you'll gain

Category: Software Testing
Category: Computer Programming
Category: Algorithms
Category: Debugging
Category: Dynamic Programming

Advanced Algorithms and Complexity

Course 527 hours4.6 (691 ratings)

What you'll learn

Skills you'll gain

Category: Priority Queue
Category: Binary Search Tree
Category: Hash Table
Category: List
Category: Stack (Abstract Data Type)

Genome Assembly Programming Challenge

Course 617 hours4.5 (338 ratings)

What you'll learn

Skills you'll gain

Category: Suffix Tree
Category: Suffix Array
Category: Knuth–Morris–Pratt (KMP) Algorithm
Category: Algorithms On Strings

Instructors

Michael Levin
University of California San Diego
7 Courses724,290 learners
Daniel M Kane
University of California San Diego
5 Courses686,017 learners
Pavel  Pevzner
University of California San Diego
16 Courses823,661 learners

Offered by

Industry partners

Partner 1
Partner 2
Partner 3

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."

New to Algorithms? Start here.

Placeholder

Open new doors with Coursera Plus

Unlimited access to 7,000+ world-class courses, hands-on projects, and job-ready certificate programs - all included in your subscription

Advance your career with an online degree

Earn a degree from world-class universities - 100% online

Join over 3,400 global companies that choose Coursera for Business

Upskill your employees to excel in the digital economy

Frequently asked questions