Your Course

Description

This course presents the fundamental data structures that are commonly used and that are the basis of other more advanced data structures and algorithms. The material covers: the classical data structures, the use of abstraction, API specification, basic search and sort algorithms, and asymptotic analysis. Also some graph representation, manipulation and algorithms are presented. Students must also demonstrate practical ability to apply the theory in building working Java classes that implement a given APIs given in the form of Java interfaces. The course reinforces programming techniques such as delegation and contracts, encapsulation and API programming, aggregation, inheritance, and polymorphism. By the end of the course, the students will be expected to be able to:

Lecture Times