Computer Science Courses

NumberNameUnitsDescription
CS 125Principles of Computer Animation1Students will learn the principles of animation developed in the 1930's by traditional animators. These principles involve a study of motion and the mind's ability to perceive motion. Principles include the notion of timing, squish and squash, arcs of motion, follow through and secondary action. Students will apply the principles of animation with the aid of 3D animation software. At the end of this course each student will develop a short animation clip. Offered alternate years.
CS 150Interdisciplinary Topics I1An interdisciplinary course that bridges the disciplines of computer science and at least one other discipline. May be repeated with permission of instructor.
CS 210Scientific Modeling1Computer Science is one of the most versatile tools for scientists. This course will use real science problems from physical and biological sciences to teach students how to build computational models to explain these problems. Focus is on the use of modeling as part of the scientific process to lead to further discovery. A working knowledge of mathematics and science is expected. Offered alternate years.
CS 220Fundamentals of Computer Science1An introduction to problem-solving, program design, testing methodology and structure of programming languages. Students will learn to program in a high-level programming language to solve problems from a wide range of computer science topics. This class makes use of laboratory experiences and is suitable for students with little to no previous experience in computer science. Satisfies the Abstraction and Formal Reasoning LADR.
CS 223Data Structure1A study of the implementation and evaluation of advanced data structures. Data structures include linked lists, stacks, queues, trees, graphs and tables with the use of recursive algorithms to perform operations. Prerequisites: 110.
CS 225Algorithmic Analysis1A systematic study of creating and evaluating algorithms, the process of solving problems. Brute force, divide-and-conquer, and problem transformation techniques are used to solve problems. Big Theta notation, best-average-worse case analysis, and notions of NP completeness are used to evaluate problems. Recommended by end of junior year. Prerequisites: 110 and one of Mat 143 or Mat 220.
CS 234Computer Organization1Fundamentals of computer organization, virtual machines, gate logic, binary arithmetic, elementary architecture, microprocessors, memory organization, machine language, assemblers and I/O implementation. Prerequisite: 110.
CS 250Interdisciplinary Topics II1An interdisciplinary course that bridges the disciplines of computer science and at least one other discipline. May be repeated with permission of instructor.
CS 324GUI and Event-Driven Programming1Focuses on the development of graphical user interfaces (GUIs) and the programming paradigms entailed by such software. Students will build their skills in problem solving and software development by encountering problems relevant to GUIs. Event handling and GUI APIs are introduced. Offered alternate years. Prerequisite: 223
CS 329Database with Web Applications1Introduction to fundamental concepts of database management systems, including database design, data definition languages, data manipulation languages, and database system implementation. Particular emphasis will be placed on implementation of web-based applications that make use of databases. Offered alternate years. Prerequisite: 223.
CS 335Theory of Computation1A mathematical investigation of the fundamental capabilities and limitations of computers. Finite automata, Turing machines, regular and context-free languages, computability and solvability, the halting problem, Church's thesis. Offered alternate years. Prerequisite: 225.
CS 336Programming Languages1A comparison of design features for selected procedural, functional, logical, or string oriented languages, syntax and semantics, assignment, control structures, data types, procedures and parameter passing, nesting and scoping. Offered alternate years. Prerequisite: 223.
CS 340Computer Networks1A study of modern communication systems, predominantly the Internet. Topics include: the client-server paradigm, use of existing protocols, creation of new protocols, P2P applications, routing algorithms, distributed sharing of resources and communicating in the face of unreliable networks. Offered alternate years. Prerequisite: 223
CS 345Operating Systems1Theory of operating systems, including memory management, concurrent processes, scheduling algorithms, device drivers, and file systems. Offered alternate years. Prerequisite: 223 or 234 (preferably both).
CS 348Artificial Intelligence1Knowledge representation, natural language processing, models of reasoning and learning, heuristic search methods, connectionism, and robotics. Offered alternate years. Prerequisite: 223 and 225.

Apply Yourself

It's quick & easy: apply online now.

Courses

Browse the courses you'll be taking.

What is...

life at Hanover like?

Find your Counselor

Get in touch with your Admission Counselor directly.

Campus Map

Explore our beautiful & unique campus.

Student Bloggers

Read up on first hand experiences of current students.

Campus Gallery

See the latest photos from around Hanover.