Assistants: (see Piazza for hours and contact info)
GTA: Shiva Ghaemi (sghaemi)
UTA: Alexander Farouz (afarouz)
Prerequisites:
CS310, CS330, and MATH125 (C or better in all)
Textbook:
Tim Roughgarden,
Algorithms Illuminated,
Omnibus Edition
Other requirements:
Access to a modern computer capable of running compiler tools (e.g. Java).
A scanner, camera, or digital drawing tool to use to prepare digital uploads of homework.
If a class cannot be held in person, be prepared to attend the lecture online, which would require a computer with reliable Internet, web browser, and audio
Lectures:
Lectures will be held in-person.
Course resources:
Piazza for questions and discussion. Please note that while Piazza now requests donations, it is due to a change in Piazza's business model independent from any input from the university; students should not feel obligated to provide donations.
Canvas to view grades and course materials, and to take quizzes.
GradeScope to for homework turn-in/feedback and exam feedback
Schedule: see below for schedule
Description
Analyzes computational resources for important problem types by alternative algorithms and their associated data structures, using mathematically rigorous techniques. Specific algorithms analyzed and improved.
Outcomes
Grade | A+ | A | A- | B+ | B | B- | C+ | C | C- | D | F |
---|---|---|---|---|---|---|---|---|---|---|---|
lower bound | 98 | 92 | 90 | 88 | 82 | 80 | 78 | 72 | 70 | 60 | ↓ |
Graded work in this class is individual unless otherwise specified on an assignment. Any direct contribution on an exam or assignment will be treated as a violation of George Mason's Academic Standards Code and the CS Department Honor Code, and will typically result in failing the class.
Generative AIs such as ChatGPT, Copilot, or Gemini should not be used to assist in completing assignments. Any assignment solved with the help of such an AI, or derived from an AI-based solution, would be in violation of the Academic Standards Code. Much like using calculators to perform arithmetic, you would not learn the skill if you used a tool to solve a problem for you, and you should not present work as your own unless you have done it yourself. AIs add an additional concern, which is that they may very confidently present incorrect answers as true, which is not helpful to your learning experience. Some kinds of participation in third-party online study sites violate the GMU Academic Standards Code: these include accessing exam questions for this class which have been uploaded by others; accessing exam or assignment answers for this class; uploading of any of the instructor's materials or exams; and uploading any of your own answers or finished work. It is your resposibility to protect your work, including protecting your computer with a password and avoiding sites which make your work publicly visible. Always consult with the professor before using these sites.
Please respect the importance of upholding the Academic Standards Code, since it affects the meaningfulness of your degree and the degrees of other students. As a practical matter, an understanding of algorithms has a strong potential to impact your ability to land a job and perform well in your future careers; you put yourself in the best position to gain that understanding when you rely on your own work.
Privacy statment
All course materials posted to Canvas or other course site are private to this class; by federal law, any materials that identify specific students (via their name, voice, or image) must not be shared with anyone not enrolled in this class. In the event that any class meetings need to be held synchronously online, those classes will be recorded to provide necessary information for students in this class. Recordings will be stored on Canvas and will only be accessible to students taking this course during this semester.
Disability accomodations
Disability Services at George Mason University is committed to providing equitable access
to learning opportunities for all students by upholding the laws that ensure equal treatment
of people with disabilities. Students seeking accommodations for this class, please first
visit Disability Services (ods@gmu.edu;
703-993-2474) for detailed information about the
Disability Services registration process. Then please discuss the approved accommodations with
the instructor. The Disability Services office can be found in Student Union Building I (SUB I),
Suite 2500.
Diversity and inclusion
George Mason University promotes a diverse, inclusive, and anti-racist environment, under the belief that a just and equitable learning environment is a strong learning environment. Students are valued as individuals, irrespective of differences in race, ethnicity, national origin, first language, economic status, gender, gender expression and identity, sexual orientation, religion, disability, or age. As an important member of the GMU community, the Department of Computer Science is integral to the goal of cultivating an environemnt which is committed to inclusion and anti-racism.
Students who prefer to be addressed by a specific name or gender pronouns should share this information with the instructor (he/him). Additionally, name and pronouns can be changed in the GMU records.
Title IX
As a faculty member and designated "Responsible Employee," the instructor is required to report all disclosures of sexual assault, interpersonal violence, and stalking to Mason's Title IX Coordinator, per university policy 1412. Students who wish to speak with someone confidentially, should contact the Student Support and Advocacy Center (ssac@gmu.edu; 703-993-3686) or Counseling and Psychological Services (caps@gmu.edu; 703-993-2380). Assistance may also be sought from GMU's Title IX Coordinator (titleix@gmu.edu; 703-993-8730).
Schedule (subject to change)
Week | Date | Topic | Assignments/Notes |
---|---|---|---|
Week 1 | Jan 19-25 | Introduction, Chapter 1 | |
Analysis Basics, Chapter 1 🅐 | |||
Week 2 | Jan 26-Feb 1 | Asymptotic Analysis, Chapter 2 🅐 | |
HW 1 assigned (Thursday) | |||
Week 3 | Feb 2-8 | Divide and Conquer; Master Method, Chapters 3, 4 🅣🅐 | Quiz 1 (open Mon-Tue) |
Week 4 | Feb 9-15 | Sorting 🅟, Chapter 5 | Quiz 2 (open Mon-Tue) |
HW 1 latest turn-in; HW 2 assigned (Thursday) | |||
Week 5 | Feb 16-22 | Graphs; Graph Algorithms, Chapters 7, 8 🅟 | Quiz 3 (open Mon-Tue) |
Week 6 | Feb 23-Mar 1 | Dijkstra's Algorithm; Greedy Algorithms, Chapters 9, 10, 13 🅟🅣 | Quiz 4 (open Mon-Tue) |
HW 2 latest turn-in; HW 3 assigned (Thursday) | |||
Week 7 | Mar 2-8 | Huffman Codes, Chapter 14 🅟 | Quiz 5 (open Mon-Tue) |
Miterm (Thursday) | Coding 1 assigned (Thursday) | ||
Week 8 | Mar 9-15 | No Classes | Spring Recess |
Week 9 | Mar 16-22 | Minimum Spanning Trees; Dynamic Programming, Chapters 15, 16 🅣🅟 | |
HW 3 latest turn-in; HW 4 assigned (Thursday) | |||
Week 10 | Mar 23-29 | Dynamic Programming; Shortest Path, Chapters 16-18 🅟🅣 | Quiz 6 (open Mon-Tue) |
Week 11 | Mar 30-Apr 5 | Shortest Path; Max Flow, Chapter 18 + Supplementary Materials 🅟 | Quiz 7 (open Mon-Tue); Coding 1 latest turn-in (Monday, 3/31) |
HW 4 latest turn-in; HW 5 assigned (Thursday) | |||
Week 12 | Apr 6-12 | Max Flow; Flow Networks, Supplementary Materials 🅟🅣 | Quiz 8 (open Mon-Tue) |
Week 13 | Apr 13-19 | Flow Networks; Hard Problems (P vs NP), Supplementary Materials, Chapters 19, 23 🅣🅟🅐 | Quiz 9 (open Mon-Tue) |
HW 5 latest turn-in; HW 6 assigned; Coding 2 assigned (Thursday) | |||
Week 14 | Apr 20-26 | Hard Problems (P vs NP), Chapters 22, 23 🅟🅐 | Quiz 10 (open Mon-Tue) |
Week 15 | Apr 27-May 3 | Randomized Algorithms; Special Topics (Internet) 🅣🅟 | Quiz 11 (open Mon-Tue) |
HW 6 latest turn-in (Thursday); Coding 2 latest turn-in (Monday, 5/5) | |||
Exam Week | May 7-14 | Final Exam Section 003 | 10:30am-1:15pm, Thursday, May 8 |
🅐 Focuses on techniques for analyzing and evaluating algorithms.
🅟 Focuses on solutions to significant algorithmic problems.
🅣 Focuses on general algorithmic techniques applicable to a wide range of problems.