We're sorry but this app doesn't work properly without JavaScript enabled. Please enable it to continue.

Learn Data Structures and Algorithms in Python

Build data structures from scratch and learn how to think through complex algorithms in Python. Practice your hard problem-solving skills and write faster code to feel confident in interviews.

What will you learn?

If you've had trouble getting past a hard whiteboarding session, this course is for you. Big-O complexity is arguably the most important concept students learn in a formal computer science degree. You'll build data structures from scratch in Python and improve your problem-solving skills. We'll cover binary trees, linked lists, stacks, graphs and more. This Python course will give you the foundation you need to start your career off on the right foot. After completing this course, you'll be comfortable crushing interview questions and writing performant code.

Chapter List

1
Algorithms Intro
Learn about what algorithms are and why they matter
2
Math
Learn the math required to understand Big-O notation, namely exponents, logarithms, and factorials
3
Big-O Analysis
Figure out what Big-O notation and time complexity mean in the context of algorithms and performant code
4
Sorting Algorithms
Learn how data is sorted on a computer, and how to sort it faster
5
Exponential Time
Understand why exponential time complexity is so dangerous
6
Data Structures Intro
Learn about data structures and how they play a critical role in algorithms
7
Stacks
Learn about stacks, the original LIFO data structure and build one from scratch
8
Queues
Learn about the FIFO queue data structure and how to implement a simple one from scratch
9
Linked Lists
Understand how linked lists vary from arrays and how to use one to build a faster queue
10
Binary Trees
Learn about binary trees, what they are used for, and implement one from scratch
11
Red Black Trees
Solve the classic balancing problem of traditional binary trees with a red-black algorithm
12
Hashmaps
Build a hashmap from scratch and learn how to use the Python dictionary type effectively
13
Tries
Build all the methods of a trie class, and efficiently search entire documents of text
14
Graphs
Learn about graph structures and how we can use them to quickly solve a wide array of search problems
15
BFS and DFS
Implement and understand the ever-famous breadth first and depth-first search algorithms
16
P vs NP
Learn about P and NP

Why settle for mediocrity?

The only way to become a great developer is to write a lot of code

Avoid tutorial hell

by writing a ton of code

Stay motivated with

dopamine-driven development

Build portfolio projects

to prove your skills

Delve deeper

into foundational concepts

Learn flexibly online

without interrupting your life

For 1% the price of college

to minimize your financial risk

Join over 500,000 students learning modern backend skills

Connect directly with them and others in our flourishing online community

15.2M

lessons completed

90K

courses completed

3.8B

xp earned

I earned my CS degree several years ago, but was unable to land a coding job. I've completed most of the learning path and I'm ecstatic to report I've started my first full-time software engineering role!

David Kennard profile image

David Kennard

Boston Technologies

Tennessee, USA

The knowledgable developers in the Boot.dev Discord helped me land my first job in just a month!

Megan Astraus profile image

Megan Astraus

Strongmind

Arizona, USA

As a Head of Data Science at a consulting company, I'm always looking to improve my skills. After completing almost all Boot.dev has to offer, I can say it's the ideal choice for backend training.

Isaac Flath profile image

Isaac Flath

Centriam

Washington D.C. USA

I've been working as a postdoc, and ever since getting my feet wet with code I have been interested in transitioning into tech. I recently completed the back-end path on Boot.dev and just landed my first professional development job!

Theo profile image

Theo

Freie Universität Berlin

Connecticut, USA

As a senior dev, the Boot.dev courses have helped me land my first Go job at Ardan Labs!

Daniel Gerep profile image

Daniel Gerep

Ardan Labs

Cássia Brazil

or view more reviews

Frequently asked Questions

Got questions? We've got answers

It's completely up to you. The time it will take you to be "job ready" will depend on how much you already know, how often you study, and how long you study for. That said, the backend career path takes many people about 12 months.


Absolutely! If you built it, use it. You'll build several personal projects while completing our curriculum, and our final course about finding jobs will show you how to construct a job-ready portfolio.


We're not a $10,000 bootcamp.

We're not a $50,000 university degree.

We are a self-paced, gamified online learning platform for back-end web development. You can learn with us for the price of a gym membership.


You can read all about our methodology here. In a nutshell, we're laser focused on teaching backend-development, which is somewhat of a rarity in online learning. We're also focused on solving what we believe is the hardest problem with online learning: boredom.

If you prefer coding rather than watching, and your struggle with online learning is staying motivated and engaged, we think you'll like learning with us.


Yes! It's free to create an account and start learning. You'll get all the immersive and interactive features for free for a few chapters. After that, if you still haven't paid for a membership, you'll be in read-only (content only) mode.