• Lab 10 is available. It is due on Saturday, December 5th before midnight.

  • The Final Exam is scheduled for Thursday, December 10th from 7pm-10pm.

  • A study guide is available for the final exam.

Course Info

Welcome to CS21. This course will introduce fundamental ideas in computer science while also teaching you how to write computer programs. We will study algorithms for solving problems and implement solutions in the Python programming language. Python is an interpreted language that is known for its ease of use. We also introduce object-oriented programming and data structures. A deeper coverage of these topics will be presented in CS 35.

This course is appropriate for all students who want to learn how to write computer programs and think like computer scientists. It is the usual first course for computer science majors and minors. Students with advanced placement credit or extensive programming experience should place out of this course and instead begin with CS31 or CS35.

Meeting Times:

All times listed are local to Swarthmore (US/Eastern time).

Section Days Time Instructor




Rich Wicentowski




Lisa Meeden

Lab Day Time Instructor



2:00pm- 3:30pm

Scout Sinclair



8:15pm- 9:45pm

Scout Sinclair



2:00pm- 3:30pm

Lisa Meeden



3:45pm- 5:15pm

Scout Sinclair




Lisa Meeden



2:00pm- 3:30pm

Rich Wicentowski



3:45pm- 5:15pm

Rich Wicentowski

Support Staff & Office Hours

Name Office Hours

Rich Wicentowski

Tuesday 3:30pm-5:30pm (and by appt)

Scout Sinclair

Friday 2:30pm-4:30pm (and by appt)

Lisa Meeden

Friday 10am-12pm (and by appt)

Lauri Courtenay

Thursday 11:30am-1:30pm (and by appt)

Academic Support Coordinator: Lauri Courtenay

Student assistants/Ninjas: Jack Ballou, Asha Bhuiyan, Sam Chen, Olivia Fey, Alex Fischmann, Sherry Huang, Emma Jin, Martina Kampel, Sydney Levy, Sojin Lim, Catherine Wang


Book Cover

We will primarily be using the online book How to think like a computer scientist: Learning with Python by Elkner, Downey and Meyers.

See the Schedule for each week’s reading assignment.

Here are a few other useful online resources:

Course Goals

By the end of the course, we hope that you will have developed the following skills:

  • Given a program, be able to simulate on paper how a computer would execute the program, and show the results that would be produced.

  • Given a problem, be able to design a clear, concise, and correct pseudocode algorithm to solve it.

  • Given a pseudocode algorithm, be able to successfully implement it in Python.

  • Be able to use top-down design to sub-divide a large problem into reasonably-sized modular sub-problems.

  • Given several algorithms for solving the same problem, be able to analyze which algorithm would be more efficient in terms of running time.

  • Develop debugging and unit testing skills. Consistently use these skills while implementing programs.



Sep 08

00A: Welcome to CS21

00B: Logistics


01A: Intro to CS

01B: Using Linux

01C: Types in python

Course Introduction

Lab 0: UNIX, editing

Sep 10

01D: Variable assignment

01E: Input/Output

01F: The 'def' keyword


Sep 15

02A: For loops

02B: range function

02C: loops with range

Numbers, Strings, and Loops

Lab 1: First Programs

Sep 17

02D: Accumulators

02E: Accum. w/ strings


Sep 22

03A: Booleans

03B: if statements

03C: Multi-way if

Conditions and Boolean Logic

Lab 2: for loops

Sep 24

Quiz 1 Study Guide

03D: Logical operators

03E: Formatted printing


Sep 29

04A: Functions

04B: Return values

04C: Stack frames

First Functions, while Loops

Lab 3: if statements, for loops

Oct 01

04D: While loops

04E: Random library


Oct 06

05A: Input validation

05B: Boolean flags

05C: Lists vs Strings

Fruitful Functions

Lab 4: while loops, functions

Oct 08

Quiz 2 Study Guide

05D: Lists with functions

05E: Lists on the stack

05F: Mutating in functions


Oct 13

06A: Files

06B: Lists of lists

06C: Top-Down Design

Top-Down Design

Lab 5: More functions

Oct 15

06D: Flashcards TDD Part 1

06E: Flashcards TDD Part 2

06F: Flashcards implementation


Oct 20

07A: Wheel of Fortune TDD Part 1

07B: Wheel of Fortune TDD Part 2

More Top-Down Design

Lab 6: Top-Down Design

Oct 22

Quiz 3 Study Guide

07C: WoF Stubs Part 1

07D: WoF Stubs Part 2

07E: WoF Implementation (Optional)


Oct 27

08A: Search

08B: Linear Search

08C: Algorithm Analysis


Continue TDD

Oct 29

08D: Binary Search

08E: Analyzing Binary Search


Nov 03

No class today--Vote!

09A: Sorting

09B: Bubble Sort


Lab 7: Searching

Nov 05

Quiz 4 Study Guide

09C: Analyzing Bubble Sort

09D: Selection Sort


Nov 10

10A: Recursion

10B: Recursion on Lists


Lab 8: Sorting

Nov 12

10C: Recursion on Strings

10D: More Recursion


Nov 17

11A: Object Oriented Programming

11B: Defining classes

Classes and Objects

Lab 9: Recursion

Nov 19

Quiz 5 Study Guide

11C: More OOP

11D: Objects on the stack


Nov 24

Thanksgiving Break

Nov 26


Dec 01

12A: Exceptions/OOP

12B: Cards part 2

More Classes and Objects

Lab 10: Defining classes

Dec 03

12C: Blackjack

12D: Semester Wrap-up

Final exam 7-10pm Study Guide (Dec 10)

Grading Policies

Grades will be weighted as follows:


Lab assignments




Final exam


Exercises, Class Participation and Attendance

Zoom Etiquette and Class Participation

A substantial portion of your grade will be based on your class participation in Zoom. Here are some tips for making our remote class time most effective:

  • Join the Zoom meeting a few minutes early in case you have to deal with any technical difficulties.

  • Class time will be interactive with lots of discussion and questions. Please leave your camera on to facilitate interactions. Feel free to use a virtual background, if you’d like.

  • Please use the Zoom "raise hand" feature to ask a question. This ensures that we will address questions in the order that they were raised. Don’t worry if other people have their hands up already: we want to hear what you have to say!

  • Unless you are speaking, please keep yourself muted. One fast way to unmute yourself is to hold down the space bar on your computer.

  • At times, we may ask all students to respond to a question in the chat window, or to a poll. Please respond promptly so that we can get a sense of the class consensus.

  • Come prepared for class with questions from the reading or videos, and be ready to share your attempts at completing the exercises assigned in the videos.

Exam and Quizzes

Quizzes will be administered through Gradescope. They will available between 9pm on Thursday and 10am the following day. Once you start the start, you will have a limited window of time, typically 30 minutes, to complete it. Quizzes will be held every other week beginning in the third week. See the schedule for exact dates. Please look over these dates carefully and contact the professor in advance if you have any unavoidable conflicts.

There will be a final exam at the end of the semester. Details and dates will be released during the semester.

If you do not complete quizzes or exams, and do not let us know ahead of time potential conflicts, you will receive a zero for that assessment.

Please read the section on accommodations if you are in need of extra time. You must inform us of accommodations or conflicts at least 2 weeks in advance of quizzes and exams.

We encourage you to visit the ninja sessions and office hours to prepare and study for quizzes and the final exam.

Lab Policy

This course features weekly lab assignments which are the largest component of your course grade. Lab attendance is required by all students. You must attend the lab session for which you are enrolled.

Lab assignments will typically be released on Sunday at the beginning of the week and will be due by midnight on Saturday. You are strongly encouraged to start early and to attend the ninja sessions for extra practice.

You will submit your assignments electronically using the handin21 program. You may submit your assignment multiple times, and a history of previous submissions will be saved. You are encouraged to submit your work regularly.

Late Policy

Late lab submissions are generally not accepted. However, given the remote nature of the class and the realities of the ongoing pandemic, we recognize that there may be times when you cannot complete the lab by the due date. Please contact your professor as soon as you suspect that you may need extra time. We will be flexible in working with you, but we will only grant exceptions for issues specifically related to the remote instruction format and illness. In all cases, even if you do not fully complete a lab assignment by the due date, you should submit what you have done to receive partial credit.

If you need an extension on an assignment or you are unable to attend class for two or more meetings due to a medical condition (e.g., extended illness, concussion, hospitalization) or other emergency, you must contact the dean’s office and your instructors. Faculty will coordinate with the deans to determine and provide the appropriate accommodations. Students should consult the College’s medical excuse policy.

Academic Integrity

Academic honesty is required in all your work. Under no circumstances may you hand in work done with (or by) someone else under your own name. Your lab work (including your python code) should never be shared with anyone; you may not examine or use lab work belonging to someone else, nor may you let anyone else look at or make a copy of your lab work. This includes, but is not limited to, obtaining solutions from students who previously took the course or code that can be found online. You may not share solutions after the due date of the assignment.

Discussing ideas and approaches to problems with others on a general level is fine (in fact, we encourage you to discuss general strategies with each other), but you should never read anyone’s python code or let anyone else read your code. All code you submit must be your own with the following permissible exceptions: code distributed in class, and code found in the course text book. In these cases, you should always include detailed comments that indicates which parts of the assignment you received help on, and what your sources were.

Failure to abide by these rules constitutes academic dishonesty and will lead to a hearing of the College Judiciary Committee. According to the Faculty Handbook: "Because plagiarism is considered to be so serious a transgression, it is the opinion of the faculty that for the first offense, failure in the course and, as appropriate, suspension for a semester or deprivation of the degree in that year is suitable; for a second offense, the penalty should normally be expulsion." Be aware that we will be routinely running plagiarism detection software on the lab solutions of students from all sections of CS21.

The spirit of this policy applies to all lab work, quizzes and exams. Please contact us if you have any questions about what is permissible in this course.

Exam Integrity

At the top of each quiz and exam, you will be asked to sign an integrity policy that affirms that your work is your own and that you have not used any unauthorized outside sources.

Any non-permitted discussion or aide in regards to quiz or exam material will result in a report to the Dean’s office. Please discuss any concerns or accommodations with your instructor prior to starting the quiz or exam.

Student Support

Lauri Courtenay is the CS Department’s Academic Support Coordinator. She will be working closely with our student mentors, also known as Ninjas, to help you learn how to program and think like a computer scientist. The CS21 Ninjas will assist us in class and run evening study sessions The CS21 Ninjas (student mentors) are: Jack Ballou, Asha Bhuiyan, Sam Chen, Olivia Fey, Alex Fischmann, Sherry Huang, Emma Jin, Martina Kampel, Sydney Levy, Sojin Lim, Catherine Wang.

Study Sessions

You are invited — and encouraged — to participate in Ninja study sessions to prepare for quizzes, to discuss programming concepts, and to get friendly assistance in working on lab assignments. Our CS mentoring team is dedicated to helping students, who have no prior knowledge of computer science, learn to program in Python while keeping their senses of humor intact.

Weekly Ninja Sessions









All meeting times are local to Swarthmore (US/Eastern time).

Remote access using ssh

To connect to the CS machines from your dorm room or home, you will need the ssh program on your machine. ssh stands for Secure Shell. It is considered secure because all communications done through ssh are encrypted. This means anyone monitoring the network traffic will only see encrypted text going by, and not what you are actually typing (like your password).

You should follow the instructions on how to connect your machine to the CS lab. If you have any problems, please contact your professor or lab instructor!

Academic Accommodations

If you believe you need accommodations for a disability or a chronic medical condition, please contact Student Disability Services via e-mail at studentdisabilityservices at to arrange an appointment to discuss your needs. As appropriate, the office will issue students with documented disabilities or medical conditions a formal Accommodations Letter. Since accommodations require early planning and are not retroactive, please contact Student Disability Services as soon as possible. For details about the accommodations process, visit the Student Disability Services website.

To receive an accommodation for a course activity, you must have an Accommodation Letter from the Office of Student Disability Services and you need to meet with us to work out the details of your accommodation at least two weeks prior to the activity.

You are also welcome to contact us privately to discuss your academic needs. However, all disability-related accommodations must be arranged, in advance, through Student Disability Services.

How to Succeed in CS21

  • Before class: read the textbook

    Don’t worry about total comprehension, but at least get a feel for what we will be covering that week. If you have some understanding of the material before watching the videos and attending class, it will be easier for you to complete the exercises and ask questions.

  • Before class: watch videos and complete the exercises

    The primary introduction to the course material is through flipped classroom videos. We expect you to watch these videos before attending the synchronous Zoom class. Most videos end with an exercise for you to work on. You should be ready to discuss your solutions to these exercises in class. It’s important for you to attempt these exercises and come to class with questions if you are unsure how to complete them.

  • Attend synchronous Zoom class

    We will use class time for you and your peers to discuss exercises from the videos. Discussing exercises is an important part of the learning process. We will also use class time to go over more examples and cover new material.

  • Ask questions if you don’t understand

    There are lots of opportunities for you to ask questions: attending class, attending lab, office hours, and ninja sessions. This class continually builds on previous material, so if you don’t understand something one week, it will continue to be a problem the next week, and the week after that, and so on.

  • Start the lab assignments early

    Before attending lab each week, you should read through the lab assignment and begin sketching out a solution, on paper or in python. If you get stuck early (i.e., not two hours before it is due), there will be time to get help from the CS21 support staff and ninjas. In addition, starting early means you can take a break, go do something else, and come back later. We find we always have at least a few new ideas when coming back to a problem after a break.

  • Practice, practice, practice

    The only way to effectively learn the material and succeed on the quizzes and final exam is to consistently do the exercises and labs. Finish all of these programs — and do some extras, for fun! Even if you don’t get them done on time, they will still help you learn the material.

  • Attend Labs and Ninja Sessions

    Lab attendance is required. The student Ninjas hold evening study sessions each week. You are encouraged to participate in these sessions. The Ninjas will help you prepare for quizzes, will provide additional instruction in programming concepts, and will provide friendly assistance on your lab assignments.

Programming Style

Programming is not a dry mechanical process, but a form of art. Well written code has an aesthetic appeal while poor form can make other programmers and instructors cringe. Programming assignments will be graded based on style and correctness. Good programming practices usually include many of the following principles:

  • A comment at the top of the program that includes

    • Program authors

    • Date or Dates

    • A brief description of what the program does

  • Concise comments that summarize major sections of your code

  • Meaningful variable and function names

  • Function comments that include:

    1. description of what function does

    2. description of input value(s) (parameter values)

    3. description of return value

  • Well organized code

  • White space or comments to improve legibility

  • Avoidance of large blocks of copy-pasted code

Emacs Commands

When using the following commands:

  • C = control key

  • M = escape key

C-x means hold the control key while also pressing the x key, the same way you might use C-c to copy.

For commands with the escape key, just press escape and release it—​don’t hold it down.

Description Command

Starting Emacs


Quitting Emacs

C-x C-c



C-x C-s

Save As…​

C-x C-w


C-x C-f

Error recovery

Abort command


Undo a change

C-x u or C-_

Cutting and pasting

Use mouse to highlight section


DELETE highlighted text (but don’t put in clipboard)


CUT highlighted text (and save to clipboard)


COPY highlighted text (and save to clipboard)


CUT from cursor to end of line (and save to clipboard)


Paste from clipboard




Multiple windows

Terminal window in emacs

C-c s

Switch windows

C-x o

Remove other windows

C-x 1


PgDown or C-v

Down on screen

PgUp or M-v

Up on screen

M - <

Beginning of file

M - >

End of file

Links that are related to the course may be posted here. If you have suggestions for links, let us know.