This course introduces software engineering students to elementary data structures and their implementation. Software abstractions via elementary data structures and their implementation; encapsulation and modularity; class and interface definitions; object instantiation; recursion; elementary abstract data types, including sequences, stacks, queues, and trees; implementation using linked structures and arrays; vectors and strings; memory models; automatic vs. dynamic memory management.
Absolute C++, 6th ed., by Savitch
(Addison-Wesley)
(Any "good" introduction C++ should
suffice.)
Introduction (3 hours)
Operating
system and Unix concepts, programming language
concepts
Introduction to C++ concepts (3
hours)
C++ basics, basic types, IO
Use of
simple library elements (string, vector)
ADT and their implementations as linked structures
(12 hours)
The stack, queue, and priority and
queue ADTS
The linked list, sorted linked list
Trees, binary trees, binary search trees
The C/C++
memory model: pointers vs references, stack vs
freestore
Implementing and travesing linked
structures
Recursion and stack frams
Recursive vs
iterative solutions to ADTs
Space and time complexity
of solutions
Simple testing and debugging
strategies
Object-based computing (9 hours)
Interface vs implementation
Class definitions, instantiation, object construction and destruction
Objects vs pointers to objects
Interface design and abstraction, responsibility allocation
The adapter design pattern
Introduction to object-oriented programming (9 hours)
Introduction to inheritance and its implementation in C++
Introduction to generics, type parameterization, and C++ templates
The template method design pattern
Use of generic data containers and the Standard Template Library
Design heuristics and strategies for object-oriented programming
Time | Room | Instructor |
---|---|---|
Mon 4:30pm - 5:30pm | DC 2340 | Prof. Mike Godfrey |
Tues 12:00pm - 1:00pm | MC 4065 | Alireza Shaeri (ISA) |
Tues 2:00pm - 4:00pm | MC 4065 | Alireza Shaeri (ISA) |
Wed 7:00pm - 8:00pm | Microsoft Teams | Helen Weixu Chen (ISA) |
Thurs 3:00pm - 6:00pm | Microsoft Teams | Weiming Ren (TA) |
Wed 1:00pm - 4:00pm | Microsoft Teams | Aniruddhan Murali (TA) |
Wed 5:30pm - 8:30pm | Microsoft Teams | Hanna Derets (TA) |
Please familiarize yourself with the policies outlined here before you direct any questions to the course account or staff.
An assignment not handed in receives a mark of 0, unless there is a documented reason. If a documented reason is approved, the weight of the missing assignment is distributed across the other assignments. All illness related issues will require a verification of illness form, signed by a doctor. See the information here
Assignments must be submitted using Marmoset, secret test
results are available post-dealine.
No assignments
need to be picked up, new assignments appear in the
downloads section after release.
MOSS
will be used to check for copied assignments /
plagiarism.
Requests for remarking an assignment must be submitted to the ISA via the course email at most two weeks after the assignment is marked. Include any supporting evidence for your case. Minor code changes (~5 lines) to fix failing test cases may be permitted, but won't receive full marks. Major changes will be ignored. Re-marking is intended for situations where minor changes result in major mark boosts (i.e. a forgotten semicolon failed 4/5 secret cases).
There will be no group work allowed on any assessments (graded or not). Please see university policies about academic integrity.
Academic Integrity: In order to maintain a culture of academic integrity, members of the University of Waterloo community are expected to promote honesty, trust, fairness, respect and responsibility. [Check www.uwaterloo.ca/academicintegrity/ for more information.]
Intellectual Property Students should be aware that this course contains the intellectual property of their instructor, TA, and/or the University of Waterloo. Intellectual property includes items such as:
Course materials and the intellectual property contained therein, are used to enhance a student's educational experience. However, sharing this intellectual property without the intellectual property owner's permission is a violation of intellectual property rights. For this reason, it is necessary to ask the instructor, TA and/or the University of Waterloo for permission before uploading and sharing the intellectual property of others online (e.g., to an online repository).
Permission from an instructor, TA or the University is also necessary before sharing the intellectual property of others from completed courses with students taking the same/similar courses in subsequent terms/years. In many cases, instructors might be happy to allow distribution of certain materials. However, doing so without expressed permission is considered a violation of intellectual property rights.
Grievance: A student who believes that a decision affecting some aspect of his/her university life has been unfair or unreasonable may have grounds for initiating a grievance. Read Policy 70, Student Petitions and Grievances, Section 4, www.adm.uwaterloo.ca/infosec/Policies/policy70.htm. When in doubt please be certain to contact the department's administrative assistant who will provide further assistance.
Discipline: A student is expected to know what constitutes academic integrity [check www.uwaterloo.ca/academicintegrity/] to avoid committing an academic offence, and to take responsibility for his/her actions. A student who is unsure whether an action constitutes an offence, or who needs help in learning how to avoid offences (e.g., plagiarism, cheating) or about 'rules' for group work/collaboration should seek guidance from the course instructor, academic advisor, or the undergraduate Associate Dean. For information on categories of offences and types of penalties, students should refer to Policy 71, Student Discipline, www.adm.uwaterloo.ca/infosec/Policies/policy71.htm0. For typical penalties check Guidelines for the Assessment of Penalties, www.adm.uwaterloo.ca/infosec/guidelines/penaltyguidelines.htm.
Appeals: A decision made or penalty imposed under Policy 70 (Student Petitions and Grievances) (other than a petition) or Policy 71 (Student Discipline) may be appealed if there is a ground. A student who believes he/she has a ground for an appeal should refer to Policy 72 (Student Appeals) www.adm.uwaterloo.ca/infosec/Policies/policy72.htm.
The Accessibility Services Office (AS), located in Needles Hall, Room 1132, collaborates with all academic departments to arrange appropriate accommodations for students with disabilities without compromising the academic integrity of the curriculum. If you require academic accommodations to lessen the impact of your disability, please register with the AS at the beginning of each academic term.
Academic Integrity and Students with Disabilities