Problem Solving with Algorithms and Data Structures

It is foolish to answer a question that you do not understand. It is sad to work for an end that you do not desire.
— George Polya

We agree with decades of conventional wisdom that familiarity with common algorithms and data structures is one of the most empowering aspects of a computer science education. This is also a great place to train one’s general problem solving abilities, which pays off in every other area of technical study.

In this course you will learn a number of important ways to model data (data structures) and answer interesting questions about them (algorithms). We are sure these will prove useful throughout your career. More importantly however, you will develop a stronger ability to understand, break down and solve novel problems, whether inventing your own techniques or repurposing those which we teach you.

Classes

  1. Technical Problem Solving and Analysis
  2. Data Structures
  3. Divide and Conquer, Sorting and Searching
  4. Graph Search: BFS and DFS
  5. Advanced Graph Search: Uniform Cost Search and A*
  6. Constraint Satisfaction Problems: Backtracking and Constraint Propagation
  7. Dynamic Programming
  8. Rapid Fire Problem Solving

Projects and exercises

This class is oriented around hands-on problem solving. While your instructor will spend some time helping you better understand certain concepts, you will mostly be solving small problems on the whiteboard and by writing code in your language of choice, to build a better intuition for the subject matter. You will also be given practice problems to work on between classes.

Assumed knowledge

This course assumes confident programming ability in any language.

Schedule and price

This course will next run 5:30pm-8:00pm Mondays and Thursdays 6-30 August. The total price is $1,800.

Apply now Still have questions? Contact us.
I thought this class would just be a refresher on concepts I had already learned, but it was so much more! To really understand how data structures and algorithms work down to caching and memory constraints made these concepts so much more applicable to my every day work. Tyler did an amazing job outlining the considerations we should make when approaching different types of problems, and I finished the course feeling extremely confident I could transfer these skills to any problem.
Martine portrait
Martine Ehrlich, Software Engineer at FutureAdvisor
Bradfield’s algorithms course greatly exceeded my expectations. I feel like I came away with an entire new mental framework for understanding, modeling, and solving difficult things in computer science. Strong recommend!
Ben Goldhaber portrait
Ben Goldhaber, Application Developer at Google
Yes, this course will help you get better at whiteboarding interviews, but that’s not the point. This is a life skills course! I learnt how to explore, model, and tackle problems in the real world. Take this course if you want to improve your mental models and become one with the age-old problem solving process: understand, plan, execute, and review.
Charlie Harrington portrait
Charlie Harrington, Software Engineer at LendUp
More so than any specific algorithm or data structure, this class ingrained a problem solving process in me that I now take with me wherever I go.
Tiger Shen portrait
Tiger Shen, Software Engineer at Braintree
Bradfield

[email protected]
576 Natoma St
San Francisco, California
© 2016 Bradfield School of Computer Science