Fall 2021
Section 01 Class Time:  MW 9:30–10:45 AM 
Section 01 Classroom:  Regents 239 
Section 02 Class Time:  TR 9:30–10:45 AM 
Section 02 Classroom:  ICC 108 
Instructor:  Mark Maloof 
Office:  325 St. Mary's Hall 
Mailbox:  329A St. Mary's Hall 
Office Hours:  Online via Zoom: TR 12:00–1:30 PM, M 10:00–11:00 AM, W 4:00–5:00 PM; please send me email for the Zoom link. (Or by appointment.) 
This course is designed as a second year course for majors and minors and covers basic data structures and algorithm analysis. Starting with the art and science of analyzing algorithms, the main goal of this course is to learn various techniques for organizing data so that computer programs can access, modify, and delete data efficiently. Topics covered include basic data structures (for example, lists, stacks and queues), trees, hashing, heaps, disjoint sets, and graphs, selfadjusting data structures; worstcase, averagecase, and amortized analysis; and basic problem solving techniques. The topics are theoretical in nature but have dramatic impact in practice.
Prerequisites: Computer Science II (COSC052) and either Mathematical Methods for Computer Science (COSC030) or Introduction to Proofs and Problem Solving (MATH200)
Required Text:
By the end of the semester, students will be able to:
My course policies are designed to supplement the University's Undergraduate Honor System and the CS Department's Honor Policy. Unless stated otherwise when I distribute an assignment, the following is the default for all assignments for this course. I have developed my policies from past teaching experiences and from the CS Department's Honor Code at George Mason University.
I am obligated to refer all suspected cases of academic dishonesty by undergraduate and master's students to Georgetown's Honor Council. I am obligated to refer all suspected cases of academic dishonesty by doctoral students to the dean of the Graduate School. If you have any questions about these policies or how they apply, please discuss such concerns with me during class, during office hours, by email, or using the class's discussion board.
In my experience, students at Georgetown do honest work. The very small percentage of students who have submitted someone else's work as their own did so because they did not manage their time wisely.
Students must always follow proper scholarly practice for all submitted work, whether graded or ungraded and whether a draft or final version of a proposal, paper, program, or problem set. As scholars, we must acknowledge our reliance on the work of others through citation. You can never submit someone else's work as your own without proper attribution. The University assumes that students learned how to properly cite material at their previous institutions. If this is not the case, please let me know.
Indeed, students may be quite adept at and knowledgeable about citing and quoting material from traditional sources, such as books and articles. Typically, we do not have cite facts, common math formulae, or expressions of our own ideas, observations, interpretations, and analyses, However, students new to computer science may not realize that theorems, proofs, algorithms, programs, and code fragments may require the same treatment as any other form of expression.
For convenience, you do not need to cite the course materials, which are the syllabus, sources linked from the syllabus, the course textbook, the class lectures and discussion, posts on the discussion board, and conversations with me and the course's teaching assistants. You must, however, cite the use of any source that is not part of the course materials. Note that “the textbook” does not extend to the textbook's Web site, its contents, lecture slides, solution manuals, code repositories, or any other material related to the textbook. The syllabus links to any such material pertinent for the class. If you are unsure about what requires citation or what constitutes proper scholarly practice, please ask me during class, during office hours, by email, or using the discussion board.
I design my courses and assignments so students have what they need to complete the assignments individually without consulting outside resources. I determine the size of and credit for assignments based on the assumption that the work for them is the result of individual effort using only the course resources and materials. Students who use outside resources to complete assignments may not be eligible for full credit. Students who do not acknowledge their use of outside resources to complete assignments may be in violation of my course policies and the university's policies on academic integrity.
The materials that I create and use for my courses (“Course Materials”) are my intellectual property. You may not disseminate or reproduce them in any form for public distribution (e.g., sale, exchange, etc.) without my written permission. Course Materials include all written or electronic documents and materials that I provide, including but not limited to syllabi, current and past assessments and their solutions (e.g., exams, homeworks, projects, problem sets, etc.), and presentations such as lectures, videos, slides, etc. Course Materials may only be used by students enrolled in the course for academic (i.e., courserelated) purposes. Furthermore, your solutions to assessments are derivative works of my copyrighted material and are therefore subject to that protection because they necessarily incorporate my protected expression. Consequently, you may not further disseminate or reproduce in any form for distribution (e.g., uploading to websites, sale, exchange, etc.) your solutions to assessments.
Published course readings (book chapters, articles, reports, etc.) available in Canvas are copyrighted material. I make these works available to students through licensed databases or fair use. They are protected by copyright law, and may not be further disseminated or reproduced in any form for distribution (e.g., uploading to websites, sale, exchange, etc.) without permission of the copyright owner.
You can find more information about intellectual property and copyright here: https://www.library.georgetown.edu/copyright. You can find more information about computer acceptable use policy and intellectual property here: https://security.georgetown.edu/itpoliciesprocedures/computersystemsaup.
Copyright issues aside, if you post your solutions to assessments on the Internet, it is possible that students in future classes will find your solutions and submit them as their own work without attribution. Naturally, students who do so violate my course policies, and the Honor Council will with high probability find them in violation and sanction them. The Honor Council may also find you in violation because you facilitated cheating and violated copyright law and the Web site's terms of service.
I understand that it is often important for securing a job or an internship for students to provide prospective employers with a portfolio of their work. I recommend that students devise a scheme for doing so that does not violate copyright law, does not violate the terms of service of the site on which you have posted material protected by copyright, and does not facilitate cheating.
The following list details acceptable and unacceptable practices:
Policies dealing logistics:
Absences will be excused for participation in a universitysponsored varsity athletics (with confirmation from the appropriate contact) and for religious holidays (for a list of religious holidays that are excused absences, please visit: https://campusministry.georgetown.edu/religious_holy_days.) You are responsible for any material covered during your absence.
Absences for minor illnesses do not count as excused, but rather count against your three allowed absences. If you will be missing more than two classes because of a serious illness or because you have been asked to quarantine, you should contact your advising dean, who will help you work with all of your professors to formulate a recovery plan. The same goes for other types of emergencies, such as family illnesses. We will deal with such absences in a compassionate way, but since they affect all of your courses, you will work with your advising dean to make a plan for getting back on track.
Finally, if you must miss class for any reason, be sure to get the lecture notes from a classmate.
For flexibility, each student has two GetOutOfJailFree cards—virtual cards, of course—and 36 grace hours. Students can use their goojf cards to obtain an additional submission to Autoloab or to avoid answering one question on the midterm or final exam. Students can use their grace hours to obtain extensions on projects. Grace hours can not be used for an extension on the final project (p5) because of university rules.
To use the cards and hours for a project, students must post a private message on Piazza before 4:30 PM ET on the day the assignment is due. There can be only one request of each type per assignment. For example, students can not use two cards for a project, and they can not make two requests to use their grace hours on an assignment. They can, however, use a card and their grace hours on a project. To use a card to avoid answering a question on an exam, students can simply mark the question accordingly (e.g., goojf).
For grace hours, students must specify the number of hours they will use. If they submit their project beyond the new deadline, it will be late and the usual deduction will apply. Once a request to use a goojf card or grace hours has been made, it can not be retracted. Unused submissions and hours can not be reclaimed. Cards and hours can not be transferred to other students. Note that cards and grace hours are intended for use in normal circumstances. Students who experience extraordinary setbacks, such as medical or family emergencies, may qualify for an extension without using their grace hours. Students in these situations should contact the instructor or their advising dean.
Name  NetID  Location  Office Hours  Operating Systems  IDEs and commandline tools 
Ben Kateman  blk43  STM G37  TR 12:30–2:30 PM  Linux (class1/csclass1), macOS  Xcode, Eclipse, subline, make, valgrind, gdb, FileZilla 
Nitin Ramachandran  nkr16  STM G37  MW 3–4:30 PM  macOS  sublime, FileZilla 
Sam Dies  spd74  STM G37  TR 11 AM–12 PM  macOS  Eclipse, Terminal, FileZilla 
Sarah Moreland  skm95  STM G37  TR 3:30–5:30 PM  macOS  Xcode, Visual Studio, vi, FileZilla, sftp and scp 
Simra Ali  sia33  STM G37  R 1:30–3:30 PM  Linux (class1/csclass1), macOS  nano, Terminal, sublime 
Victoria Lei  vwl3  STM G37  T 2–4 PM  macOS  Xcode, Eclipse, Visual Studio, sublime, valgrind, FileZilla 
Zachary Young  zjy2  STM G37  TR 5–7 PM  macOS  XCode, Eclipse, Visual Studio, make, valgrind, FileZilla 



1  Maps and Hash Tables  
2  Algorithms and Pseudocode  
3  Algorithm Analysis, Asymptotic Notation  
4  Analysis of Elementary Data Structures  
5  Trees, Binary Trees, Binary Search Trees  
6  Traversals, Operations  
7  Binary Search Trees  
8  Multiway trees, (a, b) trees, (2, 4) trees  
9  Btrees, Midterm  
10  Redblack trees  
11  AVL trees  
12  Splay Trees  
13  Heaps and Priority Queues  
14  Graph Algorithms  
14  Graph Algorithms  
16  Sorting: MergeSort and QuickSort  
String Grades::getLetterGrade() { if (grade >= 94) return "A"; else if (grade >= 90) return "A"; else if (grade >= 87) return "B+"; else if (grade >= 84) return "B"; else if (grade >= 80) return "B"; else if (grade >= 77) return "C+"; else if (grade >= 74) return "C"; else if (grade >= 70) return "C"; else if (grade >= 67) return "D+"; else if (grade >= 64) return "D"; else return "F"; } // Grades::getLetterGrade
I use automatic grading routines to assign an initial grade for the projects. It is important to emphasize that the grade you obtain from Autolab is an initial grade and may not be your final grade. There are many important aspects of a program that are difficult or impossible to assess using automatic grading routines. For example, automatic grading routines can not determine if you have written proper documentation. They can not easily assess if an implementation of an operation is optimally efficient. As a consequence, I start with the initial grade you obtain from Autolab and take further deductions if necessary.
For complete implementations, I use the following distribution as a guide:
Notice that an implementation consisting entirely method stubs would obtain an initial grade of 60%. Such an implementation is incomplete, and would be subject to further deductions based on the effort required to implement the required operations.
In addition to the above, the following deductions may be taken if applicable:
Copyright © 2020 Mark Maloof. All Rights Reserved. This material may not be published, broadcast, rewritten, or redistributed.