Skip to content

ajharris/algorithms_and_data_structures

 
 

Repository files navigation

Algorithms and Data Structures

Content

Description

An understanding of algorithms and data structures will aid the implementation of data science or machine learning methods in practice. Machine learning emphasizes prediction, scalability, and autonomy. Understanding algorithms and data structures is essential to the latter two aims of ML. Participants will be able to describe how algorithms will perform when scaled or find practical methods for computers to solve problems autonomously. Industry often requires knowledge of algorithms and data structures and the ability to communicate the solving process. This module will provide the knowledge and terminology necessary to succeed in these situations.

The module will introduce participants to terminology to discuss algorithms. This includes Big-O notation, time and space complexity. The next section will explore array-based data structures, searching, and sorting. Participants should be able to justify algorithm or data structure choices based on time and space complexity analysis. Then, participants will be introduced to recursion. We will solve problems using recursion and implement data structures that are best understood from a recursive perspective. Participants will justify their design choices. The last portion of the module will be dedicated to solving optimization problems quickly. Participants will be introduced to a variety of techniques to solve problems and identify when and how a solution can be optimized.

Learning Outcomes

By the end of the module, participants will be able to:

  1. Assess options and choices around fundamental algorithms and data structures using Big-O notation.
  2. Use recursive functions.
  3. Select appropriate data structures
  4. Translate a client-led problem into an optimization problem.
  5. Identify why code is running slowly to improve its performance.

Contacts

Questions can be submitted to the #cohort-5-help channel on Slack

  • Technical Facilitator: {Salaar Liaqat}. Messages to the Technical Facilitator can be sent on Slack.
  • Learning Support Staff: {Tiyani, Mandana, and Edward}. Messages to the Learning Support Staff can be sent on Slack.

Delivery of the Learning Module

This module will include live learning sessions and optional, asynchronous work periods. During live learning sessions, the Technical Facilitator will introduce and explain key concepts and demonstrate core skills. Learning is facilitated during this time. Before and after each live learning session, the instructional team will be available for questions related to the core concepts of the module. The Technical Facilitator will introduce concepts through a collaborative live coding session using the Python notebooks found under /01_materials/slides. The Technical Facilitator will also upload live coding files to this repository for participants to revisit under ./06_this_cohort/live_code.

Optional work periods are to be used to seek help from peers, the Learning Support team, and to work through the homework and assignments in the learning module, with access to live help. Content is not facilitated, but rather this time should be driven by participants. We encourage participants to come to these work periods with questions and problems to work through.   Participants are encouraged to engage actively during the learning module. They key to developing the core skills in each learning module is through practice. The more participants engage in coding along with the instructional team, and applying the skills in each module, the more likely it is that these skills will solidify.

Schedule

Live Learning Session Topic Resources
1 Motivation and Big-O Notation Slides
2 Data Structures, Sorting, and Searching Slides
3 Recursion Slides
4 Recursive Data Structures Slides
5 Slow Code Slides
6 Case Study -

Requirements

  • Participants are expected to have completed Shell, Git, and Python learning modules.
  • Participants are encouraged to ask questions, and collaborate with others to enhance learning.
  • Participants must have a computer and an internet connection to participate in online activities.
  • Participants must not use generative AI such as ChatGPT to generate code in order to complete assignments. It should be used as a supportive tool to seek out answers to questions you may have.
  • We expect participants to have completed the instructions mentioned in the onboarding repo.
  • We encourage participants to default to having their camera on at all times, and turning the camera off only as needed. This will greatly enhance the learning experience for all participants and provides real-time feedback for the instructional team.
  • Participants must have VSCode installed with the following extensions:

Assignments

Participants should review the Assignment Submission Guide for instructions on how to complete assignments in this module.

Assessment Description Due Date
Assignment 1 DSA coding practice Sunday, Oct 12 2025 (11:59pm)
Assignment 2 Mock interview Sunday, Oct 19 2025 2025 (11:59pm)

Resources

Feel free to use the following as resources:

Concept Map

data_structures_and_algorithms_concept_map.png

Textbooks

The course content, slides, and recommended problems follow these two textbooks. They are freely available online after a quick Google search.

  • Bhargava, A. Y. (2016). Grokking algorithms: An illustrated guide for programmers and other curious people. Manning. (link)
    • This textbook is easy to understand and very accessible. We will go deeper than this text.
  • Cormen, T. H. (Ed.). (2009). Introduction to algorithms (3rd ed). MIT Press.
    • We won't cover the majority of this textbook. Many topics are too advanced and it goes into a lot of detail.

Documents

Videos

How to Get Help

1. Gather information about your problem

  • Copy and paste your error message
  • Copy and paste the code that caused the error, and the last few commands leading up to the error
  • Write down what you are trying to accomplish with your code. Include both the specific action, and the bigger picture and context
  • (optional) Take a screenshot of your entire workspace

2. Try searching the web for your error message

  • Sometimes, the error has common solutions that can be easy to find!
    • This will be faster than waiting for an answer
  • If none of the solutions apply, consider asking a Generative AI tool
    • Paste your code, the error message, and a description of your overall goals

3. Try asking in your cohort's Slack help channel

  • Since we're all working through the same material, there's a good chance one of your peers has encountered the same error, or has already solved it
  • Try searching in the DSI Certificates Slack help channel for whether a similar query has been posted
  • If the question has not yet been answered, post your question!
    • Describe your the overall goals, the context, and the specific details of what you were trying to accomplish
    • Make sure to copy and paste your code, your error message
    • Copying and pasting helps:
      1. Your peers and teaching team quickly try out your code
      2. Others to find your question in the future

Great resources on how to ask good technical questions that get useful answers


Folder Structure

.
├── .github
├── 01_materials
├── 02_activities
├── 03_instructional_team
├── 04_this_cohort
├── .gitignore
├── LICENSE
└── README.md
  • .github: Contains issue templates and pull request templates for the repository.
  • materials: Module slides and interactive notebooks (.ipynb files) used during learning sessions.
  • activities: Contains graded assignments, exercises, and homework to practice concepts covered in the learning module.
  • instructional_team: Resources for the instructional team.
  • this_cohort: Additional materials and resources for cohort three.
  • .gitignore: Files to exclude from this folder, specified by the Technical Facilitator
  • LICENSE: The license for this repository.
  • README: This file.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Jupyter Notebook 100.0%