Focuses on the common structures used to store data and the standard algorithms for manipulating them. Standard data structures include lists, stacks, queues, trees, heaps, hash tables, and graphs. Standard algorithms include searching, sorting, and traversals. Along with implementation details, students will learn to analyze the time and space efficiency of algorithms and how to select appropriate data structures and algorithms for a specific application. In homework, labs, and programming projects, students will implement their own data structures and make use of existing libraries to solve a variety of computational problems.

Section B
Semester Fall 2022
Date Time, Location
  • lecture: M-W-F 10:00 - 10:50 am, Davis 301
  • lab A: M 1:00 - 2:20 pm Davis 102
  • lab B: M 2:30 - 3:50 pm Davis 102
  • lab C: T 1:00 - 2:20 pm Davis 102
  • lab D: T 2:30 - 3:50 pm Davis 102
Instructor Prof. Naser Al Madi
Office: Davis 215
Office hours: Check my page
Lab Instructor Dr. Max Bender
Office: Davis 203
Weekly Course Schedule

The following structure will rarely change.

Day and time Activity
Monday Homework assigned
Monday, 11:59 pm Previous week's project due
Monday Project assigned in lab
Thursday, noon Homework due
Friday Weekly or biweekly quiz assigned
Saturday, 11:59 pm Quiz due
Evening TAs

In order to provide as much help as possible to you as you work on assignments in this course, the CS Department has hired the following upper-level CS students to work as TAs in Davis in the evenings. You are strongly encouraged to take advantage of this resource.

TA Hours: All TA sessions will be in person in Fall 2022. We have evening TAs from Sunday to Thursday weekly this fall except during the fall break and Thanksgiving break. Here is the TA schedule and Windows Support.

Course Goals The learning goals for the lecture and lab are the same -- both are meant to work together to accomplish the goals for the course as a whole. They are
  1. Students understand the advantages and disadvantages of fundamental data structures and can implement them using object- oriented design principles.
  2. Students understand, can implement, and can calculate the time and space efficiency of classic search, sort, and traversal algorithms, including the use of big-Oh notation.
  3. Students understand the tradeoffs between different implementations of data structures and algorithms and can make appropriate design decisions based on application data requirements.
  4. Students can use fundamental data structures and algorithms appropriately to solve a variety of computational problems.
  5. Students can communicate the results of their work and describe an algorithm.
Labs and Projects

The work in lab will lead into and be part of the week's project. Labs will also count significantly towards participation.

During each lab, the instructor will not be able to answer questions about any projects until you have completed the exercises for that lab.

Programming projects involve completing more significant programs as well as a writeup describing the work completed in the project.


There will be regular opportunities for you to practice what you have learned and to demonstrate your accomplishments.

The course grade will be determined as follows:

Labs and Projects 45%

Hands-on opportunities to implement and explore concepts from lecture.

Short homework assignments 5% Graded in a binary fashion:
1 if you made a serious attempt
0 otherwise.
Quizzes 25% Short weekly or biweekly quizzes.
Participation 5% I expect you to be an active contributor in the classroom. This requires you to attend both lectures and lab. It is not a problem if you know that you will not be able to attend a lecture or lab, but please email me in advance to let me know.
Final Exam 20% A 3-hour opportunity at the end of the semester to demonstrate your ability to answer questions about course material.
  • I will distribute short homework assignments in my lecture slides and post the homework separately on Moodle.
  • The homeworks themselves may not be worth much of your overall grade, but they prepare you for the quiz on Friday! Take them seriously and you should be well-prepared for the quiz.
  • Each homework is due by midnight of the following day.. This is a hard deadline.
    Late submissions will not be accepted.
  • Homework will be graded in a binary fashion: if you hand in a reasonable attempt, you get a 1, otherwise a 0.
Weekly quizzes
  • There is a 15 minute quiz most Fridays online on Moodle. You will have a ~1 day window to complete the quiz at a time that works best with your schedule (until Saturday night at 11:59pm).
  • The quizzes let you show me what you have learned. These should be quick and straightforward if you participate in lecture and review lecture notes.
  • I understand that everyone has a bad day; the quiz with the lowest grade will be dropped.
  • Each quiz may be made up when a prior request is made or there is a documented health issue.
  • Please contact me immediately in the event of illness and other unforeseen circumstances, we will work out accommodations.
Class Participation
  • You are expected to attend every class and lab. This is important for the overall learning experience and cohesion of the course.
  • If you must miss a class for any reason, please email me in advance. I am happy to work with you.
  • For this course to be truly successful, your presence and participation is important. When you have a question, ask it. It is highly probable that one of your classmates has the same question.
Final Exam

There will be a final exam at TBD. There are no make-ups.


It should go without saying that you should back up any files related to this course. If the code you submit to us is somehow lost (through your fault or our fault), I must be able to get another copy from you. I suggest keeping your CS231 labs and projects on Google Drive, Dropbox, or Microsoft OneDrive. That way, you have a backup stored in the cloud.


There is no required textbook for this course. All lecture notes and code from class will be posted on Moodle.

There are also lots of on-line resources available.

Links to free online data structures textbooks:
How to succeed

Labs and Projects: Come to lab ready to focus on the new project. Ask the instructor and TAs for help if you need it.

Quizzes: Study for the quizzes by doing the homeworks. We will drop the lowest quiz grade. If you make a silly mistake one week, it won't affect your grade.

Short homeworks: Try them. You will receive full credit as long as you make an honest attempt to complete every question. Please ask or email questions if something isn't clear. As long as you submit your response by Thursday at noon on Moodle, you will get credit. Review the homework solutions on Thursday afternoon to check your understanding of the material before the quiz. There is no partial credit for late homeworks because we may go over the answers in class on Friday before you take the quiz.

Participation: Speak up in class. Come to office hours. Ask your your instructors or TA for help.

Final Exam: The final exam will be similar to a large set of quizzes (but written from a more wholistic perspective). The best way to study for the final exam is to retake all of the old quizzes. Also, read through your notes and make sure you understand everything in them.

Collaboration, Academic honesty

Computer science, both academically and professionally, is a collaborative discipline. In any collaboration, however, all parties are expected to make their own contributions and to generously credit the contributions of others. In our class, therefore, collaboration on assignments is encouraged, but you as an individual are responsible for understanding all the material in the assignment and doing your own work. Always strive to do your best, give generous credit to others, start early, and seek help early from both your professors and classmates.

The following rules are intended to help you get the most out of your education and to clarify the line between honest and dishonest work. We reserve the right to ask you to verbally explain the reasoning behind any answer or code that you turn in and to modify your project grade based on your answers. It is vitally important that you turn in work that is your own. We do use automated plagiarism detection software, so please be sure to abide by these, rather minimal, rules. Reports of academic dishonesty are handled by an academic review board and a finding of academic dishonesty may result in significant sanctions. For more details on Colby's Academic Integrity policies and procedures, see

  • If you have had a substantive discussion of any homework or programming solution with a classmate, then be sure to cite them in your write-up. If you are unsure of what constitutes "substantive", then ask me or err on the side of caution. As one rule of thumb, you may discuss your approach to solving a problem, but you must not share or look at another classmate's code or written answers to project questions.
  • You must not copy answers or code from another student either by hand or electronically. Another way to think about it is that you should communicate with one another in natural human sentences, not in lines of code from a programming language.
The Colby Affirmation

Colby College is a community dedicated to learning and committed to the growth and well-being of all its members.

As a community devoted to intellectual growth, we value academic integrity. We agree to take ownership of our academic work, to submit only work that is our own, to fully acknowledge the research and ideas of others in our work, and to abide by the instructions and regulations governing academic work established by the faculty.

As a community built on respect for ourselves, each other, and our physical environment, we recognize the diversity of people who have gathered here and that genuine inclusivity requires active, honest, and compassionate engagement with one another. We agree to respect each other, to honor community expectations, and to comply with College policies.

As a member of this community, I pledge to hold myself and others accountable to these values. More ...

Title IX Statement

Colby College prohibits and will not tolerate sexual misconduct or gender-based discrimination of any kind. Colby is legally obligated to investigate sexual misconduct (including, but not limited to sexual assault and sexual harassment).

If you wish to speak confidentially about an incident of sexual misconduct, please contact Colby Counseling Services (207-859-4490) or the Director of the Gender and Sexual Diversity Program, Emily Schusterbauer (207-859-4093).

Students should be aware that faculty members are considered responsible employees; as such, if you disclose an incident of sexual misconduct to a faculty member, they have an obligation to report it to Colby's Title IX Coordinator. "Disclosure" may include communication in-person, via email/phone/text, or through class assignments.

To learn more about sexual misconduct or report an incident, visit

© 2022 Naser Al Madi. Page last modified: .