Computer Science 312 - Algorithms
Algorithms
Spring
2021
01
4.00
Audrey Lee St. John
M 09:45AM-11:00AM;TTH 09:30AM-11:15AM;WF 10:15AM-11:15AM
Mount Holyoke College
113313
astjohn@mtholyoke.edu
How does Mapquest find the best route between two locations? How do computers help to decode the human genome? At the heart of these and other complex computer applications are nontrivial algorithms. While algorithms must be specialized to an application, there are some standard ways of approaching algorithmic problems that tend to be useful in many applications. Among other topics, we will explore graph algorithms, greedy algorithms, divide-and-conquer, dynamic programming, and network flow. We will learn to recognize when to apply each of these strategies as well as to evaluate the expected runtime costs of the algorithms we design.
Prereq: COMSC-201 or COMSC-205 or COMSC-205PY; MATH-232.