Official Course Description. This course will further develop and expand upon the topics introduced in CS 141. Advanced programming techniques will be covered, with extensive use of recursion and dynamic data structures. Abstract data types, including lists, queues, trees and graphs, will be studied. Specific emphasis will be given to tree traversals and binary search trees. Algorithms for searching and sorting will be explored along with methods of comparative analysis. The topics in this course provide an essential foundation for the further study of computer science.
Prerequisites. CS141 or equivalent.
Location and Times. Science Center 354, TuTh 11:00-12:15.
Instructor. Chris Lynch. Science Center 377, 268-2384, firstname.lastname@example.org.
Office Hours. TTh 2:30-5:00 but they will probably change
Teaching Assistant. Todd Deshane. Office Hours: TBA, in the ITL lab (SC334).
Required Text. Online book. Table of Contents, Chapter 1, Chapter 2, Chapter 3, Chapter 4, Appendix, Bibliography.
Topics to be covered. Data abstraction, classes, object-oriented design, lists, vectors, stacks, queues, linked lists, iterators, templates, the STL, analysis of algorithms, recursion, sound programming principles. If time permits, inheritance, polymorphism, trees and binary search trees.
Grading. Your evaluation will be based on several homework assignments, which will be mostly programming assignments, two tests, and a final exam. Your course grade will be computed using the following formula:
I will soon give dates for the two exams.
Policy for missed work. There will be no make-up assignments. Late assignments may be accepted if a good excuse is provided and if arrangements are made at a reasonable time, in advance, if possible. Make-up tests can be arranged under the same conditions. Other special arrangements can be made for students forced to miss more than a few days of class.