STEM Program

Algorithms, Data Structures, and Python

Faculty Advisor: Professor and Director of Undergraduate Studies, Mathematics, Georgia Institute of Technology

Research Program Introduction

Algorithms are the heart of computer science. The subject has countless practical applications as well as intellectual depth. In this program, you will learn algorithms, data structures, and Python programming language. Students who enjoy mathematics and/or computer science will enjoy this program. After completing this program, students will understand how many real-world programs work and will also be able to write their own programs in Python.

Algorithms require data. When we think of data, we think of tables with information, like Excel spreadsheets. However, data is stored in different forms. These different forms are called data structures. Examples of data structures that you will learn about in this program include queues, trees, and stacks. The selection of the right data structure is fundamental to the development of efficient algorithms. Python is one of the most modern and used programming languages. 

In this program, you will learn the most powerful and commonly used classes of algorithms, how data is arranged in different data structures to support the algorithms, and the programming language Python to implement the different algorithms. You will be provided with videos and other material to supplement your learning (including programming exercises to practice). Your assignment will be to select a project from the list. This project will lead to your programming an algorithm in Python and writing a paper explaining your work and findings. You will be asked to select your project within two weeks of the first meeting. You will be asked to do a small informal presentation (5 to 10 minutes) during the last meeting and complete your paper.

Possible Topics Covered in Meetings:

  • Why study algorithms?

  • Introduction to Python: data types, variables, and basic operations

  • Basic algorithms and their implementation in Python

  • Fibonacci numbers: naïve vs efficient algorithms

  • Greatest common divisor and Euclidean algorithm

  • Big-O notation and computing run times

  • Greedy algorithms: main ideas and examples

  • Dynamic programming: revisiting the money change problem

  • Python implementations of greedy and dynamic programming algorithms

  • Divide and conquer algorithms: Naïve sort vs Merge sort

  • Probability: outcomes, events, and random variables

  • Simulations in Python

  • Trees, binary trees, and object-oriented programming in Python

  • Graphs and graph algorithms

  • Introduction to video game creation using Pygame 

Possible Topics For Final Project: 

  • Design Your Own Video Game with Pygame

  • Crack the Code: Build a Sudoku Solver Using Backtracking

  • Map It Out: Find the Fastest Path with Graph Algorithms

  • Optimize Your Travel: Create an Algorithm for the Best Flight Itineraries

  • Decode the DNA: Implement Genome Reconstruction Algorithms

  • Discover DNA Secrets: Build an Algorithm to Find Functional DNA Segments

  • Encrypt and Secure: Develop a Cryptographic Algorithm

  • Shape the World: Apply Computational Geometry to Build Maps

  • Shrink It Down: Master File Compression Algorithms

  • Balance the Books: Create a Cash Flow Minimizer Algorithm

  • Conquer Mazes: Design and Code a Maze-Solving Algorithm

  • Other professor-approved topics in this subject area that you are interested in

Program Detail

  • Cohort size: 3 to 5 students

  • Duration: 12 weeks

  • Workload: Around 4 hours per week (including class and homework time)

  • Target students: 9 to 12th graders interested in Mathematics, Computer Science, Machine Learning, and/or Interdisciplinary STEM studies

  • Prerequisites: None. Students are not expected to know Python, have any programming experience, or know anything about algorithms or data structures. The faculty advisor will provide all the necessary materials for learning.

  • Schedule: TBD (meetings will take place for around one hour per week, with a weekly meeting day and time to be determined a few weeks prior to the class start date)