COMP 2231: Data Structures and Algorithms
Students are introduced to new types of data structures such as trees (including binary and multiway trees), heaps, stacks, and queues. Students also design new algorithms for each data structure studied, create and perform simple operations on graph data structures, describe and implement common algorithms for working with advanced data structures, and recognize which data structure is the most appropriate for solving a particular problem.
Learning outcomes
- Work with procedural and object-oriented aspects of the Java language.
- Develop sound techniques on designing, developing, and documenting well-structured programs using proper software engineering principles.
- Continue to apply problem solving skills and provide a foundation for advanced programming courses using an OOP (object-oriented programming) methodology.
- Describe and implement common data structures––lists, stacks, queues, graphs, and trees––for solving complex programming problems.
- Use mathematical techniques to analyse the efficiency of the various algorithms presented, as well as the common operations on the data structures discussed.
Course topics
- Module 1: Analysis of Algorithms & Searching and Sorting
- Module 2: Stacks & Queues
- Module 3: Lists & Iterators
- Module 4: Trees & Binary Search Trees
- Module 5: Heaps and Priority Queues, Graphs & Hashing
Required text and materials
The following textbook would have been purchased in COMP 1131. Students who did not take COMP 1131 and/or don't already own the required textbook, will need to purchase it. To do so, please contact Enrolment Services at student@tru.ca or 1.800.663.9711 (toll-free in Canada), 250.852.7000 (Kamloops, BC), and 1.250.852.7000 (International).
- Chase, J., Lewis, J., and DePasquale, P. (2020). Java foundations: Introduction to program
design & data structures. (5th ed.) Toronto, ON, Pearson: Addison-Wesley.
Type: Textbook: ISBN: 978-0-13-520597-6
Additional requirements
Java Development Environment: Since this is a programming course, you will also require a development environment to compile and run your programs. Module 1 contains instructions for installing either JCreator LE or Eclipse for the Windows environment, or BlueJ for the Apple Mac environment. All of these are suitable for a learning programmer. The environment you may have used for COMP 1131 and 1231 is sufficient for this course as well.
Assessments
Please be aware that should your course have a final exam, you are responsible for the fee to the online proctoring service, ProctorU, or to the in-person approved Testing Centre. Please contact exams@tru.ca with any questions about this.
To successfully complete this course, students must achieve a passing grade of 50% or higher on the overall course, and 50% or higher on the final mandatory examination.
Note: The final exam for this course is only available as a paper exam and must be taken in person at an approved Testing Centre. Please email exams@tru.ca with any questions.
Quiz 1 | 2% |
Assignment 1: Analysis of Algorithms | 8% |
Quiz 2 | 2% |
Assignment 2 : Stacks and Queues | 8% |
Quiz 3 | 2% |
Assignment 3: Lists and Iterators | 8% |
Quiz 4 | 2% |
Assignment 4: Trees and Binary Search Trees | 8% |
Quiz 5 | 2% |
Assignment 5: Heaps, Priority Queues, Graphs and Hashing | 8% |
Final Examination (mandatory) | 50% |
Total | 100% |
Open Learning Faculty Member Information
An Open Learning Faculty Member is available to assist students. Students will receive the necessary contact information at the start of the course.