This course studies the fundamental ideas for efficiently analyzing large amounts of data, such as DNA sequence databases and geographic information. These fundamental ideas come in two kinds: algorithms and data structures. Algorithms are instructions for solving problems and data structures are strategies for organizing information on computers. Efficient algorithms require appropriate data structures, and vice versa, so the study of algorithms and data structures is tightly linked. In this course we learn about the algorithms and data structures that form the building blocks for most of Today's large-scale computer systems. We apply these ideas to solve challenging problems in bioinformatics and geographic information systems. Warning: a possible side-effect of taking this course is doing better on job interview questions.


Jeremy Siek, Office hours: 1:00-3:00 PM Fridays, and by appointment. Office: LH 230D.

Assistant Instructors


4:00 PM - 5:15 PM, Monday and Wednesday, Swain East 105

Textbook (required)

Data Structures and Algorithms in Python, by Goodrich, Tamassia, and Goldwasser. ISBN: 978-1-118-29027-9, also available as an e-Book

Course Schedule

 For the course schedule, follow this link.

Course Summary:

Date Details