Course Overview and Welcome
Hi there 👋, and welcome to CS106B: Programming Abstractions! This is the second course in our introductory programming sequence. The prerequisite, CS106A, establishes a solid foundation in programming methodology and problem-solving in Python. With that under your belt, CS106B will acquaint you with the C++ programming language and introduce advanced programming techniques such as recursion, algorithm analysis, and data abstraction, explore classic data structures and algorithms, and give you practice applying these tools to solving complex problems.
We're excited to share this great material with you and have a superb team of section leaders that will support you through the challenges to come. We hope you will find the time worth your investment and that you enjoy your growing mastery of the art of programming!
Teaching Team



In addition to our instructor and Head TAs, this course is supported by a ✨ phenomenal ✨ group of section leaders (SLs) who lead weekly sections and help students 1-on-1 in LaIR hours. Our SLs not only know the course material incredibly well, but they're also some of the kindest and most uplifting folks you'll meet on campus. (Read more about the teaching team and office/LaIR hours here.) We are all looking forward to working with you and supporting you this quarter!




















Course Topics
Overview of Main Topics
Our planned curriculum will cover the following topics in this approximate order:
- C++ basics
- Data abstraction, classic ADTs
- Recursion and backtracking
- Classes and object-oriented programming
- Pointers and dynamic memory
- Linked data structures
- Advanced algorithms
Learning Goals
After completing CS106B, we hope you will have achieved the following learning goals:
- I am excited to use programming to solve real-world problems I encounter outside class.
- I recognize and understand common abstractions in computer science.
- I can identify programmatic concepts present in everyday technologies because I understand how computers process and organize information.
- I can break down complex problems into smaller subproblems by applying my algorithmic reasoning and recursive problem-solving skills.
- I can evaluate design tradeoffs when creating data structures and algorithms or utilizing them to implement technological solutions.
We’ll also be giving you tools to tackle the following questions (note that these don’t have single right or wrong answers!):
- What is possible with technology and code? What isn’t possible?
- How can I use programming to solve problems that I otherwise would not be able to?
- What makes for a “good” algorithm or data structure? Why?
- Which problems should I solve with algorithms and data structures? What does a responsible programmer do when using data about real people?
Prerequisites
The prerequisite for CS106B is completion of CS106A and readiness to move on to advanced programming topics. A comparable introductory programming course or experience (including high school AP courses) is often a reasonable substitute for Stanford’s CS106A. If you are unsure if this course is the right for you, read more about course placement.
Course Tools
The central place for CS106B resources is the course website right here at https://cs106b.stanford.edu. The website is your go-to for course materials (lectures, assignments, sections, exams) and course policies and information.
We also make use use these additional tools:
- Canvas to publish lecture videos and lecture quizzes.
- Ed Discussion forum for online community, Q&A, and posted announcements.
- Paperless, our custom site for submitting assignments and viewing grading feedback.
- LaIR, our custom tool for mananging the queue in helper hours.
- Gradescope for viewing graded exams.
- PollEV for lecture attendance and participation.
Lectures
Lecture meets MWF 1:30 PM - 2:20 PM in Hewlett 200. Throughout the quarter, lectures will be recorded and made available on Canvas.
It's important to keep pace with the lectures rather than to batch them up and watch them all in one go. (That model works great for Netflix shows that really hook you in, but it's not great for learning.) To give you an incentive to stay on top of lectures, we've reserved 5% of your grade for lecture participation. Here are the details: starting on Monday, April 7th, we'll have at least one quick check-in through PollEV in each lecture. In cases where these check-ins ask about lecture topics, you will earn participation credit if you meaningfully attempt to answer those questions, regardless of whether your answers are correct.
Anyone participating via PollEV is expected to be present in lecture in person. If you would prefer not to attend lecture in person, in Week 4 we will send out a form that will give you the option to instead count your final exam score in place of your lecture participation grade.
To allow for some flexibility, you're allowed to miss the credit opportunity (i.e. not completing PollEV) for three lectures over the course of the quarter and still earn the full 5%.
If you are a CGOE student, then we will drop the participation portion of your grade when computing raw scores, renormalizing the remaining 95% of your grade back up to 100%. However, when calculating final letter grades, we will ensure this does not place you at a disadvantage compared to those who were able to earn participation credit through PollEV.
Note about recording consent: Video cameras are located in the back of the lecture room to capture the instructor presentation. These recordings might be reused in other Stanford courses, viewed by other Stanford students, faculty, or staff, or used for other education and research purposes. While the cameras are positioned with the intention of recording only the instructor, occasionally a part of your image or voice might be incidentally captured. If you have questions, please contact a member of the teaching team.
Sections
Each students is assigned to a weekly small group discussion section, led by an undergraduate section leader. Your section leader is your mentor, grader, and personal connection to the greater CS106B course staff.
Section sign-up will take place during the first week of classes, with section beginning in Week 2. Section attendance and participation are mandatory for all students. Your section leader will evaluate your section participation; this contributes to 5% of your course grade.
Read more about section.
Assignments
There will be regular assignments, about one per week. An assignment may include written problems, hands-on exercises with the tools, coding tasks and/or a larger complete program. Assignments are to be completed individually.
Programs are graded on "functionality" (is the program's behavior correct?) and "style" (is the code well-written and designed cleanly?). We use a bucket grading scale to focus attention on the qualitative rather than quantitative feedback. Read more about assignments, grading, and late policy.
Exams
We will have one midterm and one final exam. The midterm is a check-in to assess your understanding of core topics covered in the first half of the course and help you chart a path forward. The final is a comprehensive assessment of your mastery of the course learning goals.
Mark these dates in your calendar now!
- Midterm: Monday, April 28, 7:00 - 9:00 PM
- Final: Friday, June 6, 8:30 - 11:30 AM
All exams are in-person, pencil-and-paper exams. All students, except for CGOE students, are expected to be on campus for the exams.
CGOE students will take the exams remotely with an exam monitors. CGOE students may take their exams during any 2-hour period for the midterm and any 3-hour period for the final, on the day of the exam. For example, a CGOE student may take the midterm exam during any 2-hour slot between 12:01 AM and 11:59 PM (Pacific time) on Monday, April 28, and take the final during any 3-hour slot between 12:01 AM and 11:59 PM (Pacific time) on Friday, June 6.
Read more about exams.
Exam Proctoring
This course is participating in the proctoring pilot overseen by the Academic Integrity Working Group (AIWG). The purpose of this pilot is to determine the efficacy of proctoring and develop effective practices for proctoring in-person exams at Stanford. To find more details on the pilot or the working group, please visit the AIWG's webpage.
For more information about the goals of the proctoring pilot and information about how any survey data will be used, see:

Exam-Related Accommodations
Super important note! In accordance with regulations for all courses participating in this quarter's proctoring study, we will only be able to implement exam-related OAE accommodations if they reach us at least 10 days prior to the exam.
Course Grades
Final grades for the course will be determined using the following weights:
- 38% Programming Assignments
- 20% Midterm Exam
- 30% Final Exam
- 5% Section Participation
- 5% Lecture Participation
- 2% Quiz 0 on Canvas
In order to receive a passing grade in the course, you must earn a passing grade on the programming assignments as well as (collectively) the exams (i.e., failing one exam will not disqualify you from passing the course, as long as your average across both exams is a passing grade). So, someone who has a passing exam average but a failing average on the programming assignments, or vice versa, will not receive a passing grade in the course.
Units
If you are an undergraduate, you must enroll in CS106B for 5 units (this is by department and university policy, no exceptions). If you are a graduate student, you may enroll in CS106B for 3 or 4 units to reduce your units for administrative reasons. Taking the course for reduced units has no change on the course workload.
Policies
Incompletes
The university “I” grade (“incomplete”) is sometimes appropriate for circumstances of significant personal or family emergency disruption that occur late in the quarter and prevent a student from finishing course requirements on schedule. In order to be eligible for an Incomplete, University policy stipulates that a student must have completed a “substantial” part of the course work in “satisfactory” fashion. There must also be extenuating circumstances that warrant an extension of time beyond the end of the quarter to complete the remaining work. Approval for an incomplete is at the instructors’ discretion. Incompletes are not be considered for reasons such as poor performance in the course or over-commitment. Withdrawal from the course is more appropriate in those cases.
Time Is of the Essence
We require timely notification if any circumstances arise that impact your ability to meet the requirements, deadlines, and expectations of the course in a way that our late assignment submission policy does not already accommodate – generally in advance of any impacted deadlines (including exam dates).
Generally speaking, we ask that you treat this course as you would any professional obligation. Think of project deadlines and exam dates the same way you would think of big project deadlines at work: if it became clear you weren't going to be able to meet such a deadline, or if you weren't going to have a presentation ready in time for a big quarterly staff meeting, your manager would want to know about that well in advance.
Honor Code
As a student taking a Stanford course, you agree to abide by the Stanford Honor Code, and we expect you to read over and follow our specific CS106B Honor Code policy. The work you submit for grading must be your own original, independent effort and must not be based on, guided by, or jointly developed with the work of others.
The CS department employs powerful automated plagiarism detection tools that compare assignment submissions with other submissions from the current and previous quarters, as well as related online resources. The tools also analyze your intermediate work, and we will run the tools on every assignment you submit.
The vast majority of you are here to learn and will do honest work for an honest grade. We celebrate and honor your commitment. Because it’s important that all cases of academic dishonesty are identified for the sake of those playing by the rules, we will refer all cases of concern to the Office of Community Standards.
Regret Clause
When people are under pressure, they sometimes do things they later regret. Our impression from talking with students over the years is that this is often the case with students who violate the Honor Code in our classes: they’re good people who make bad decisions they almost immediately regret. Accordingly, if you end up violating the Honor Code while working on an assignment in this course, you can mitigate the consequences by informing me of your infraction within 72 hours after the late deadline for the assignment. In response, the only penalty you will face for that infraction is a zero on the assignment. We will not lower your grade further as a result of the infraction, and we will not refer the matter to the Office of Community Standards.
To take advantage of this "regret clause," you must fill out the Google form we will make available after each assignment deadline. We will not allow retractions outside the 72-hour window for each assignment, and we will not do a last call for retractions at the end of the quarter.
Note that the Regret Clause applies only to assignments (not exams).
This policy is modeled after the regret clause in Harvard's CS50 class.
Course Resources
Textbook
Roberts, Eric. Programming Abstractions in C++. ISBN 978-0133454840.
You can find different options to access the textbook here . Recommended readings for each lecture will be posted on our lecture schedule.
Software
The official CS106 programming environment is Qt Creator, which is an editor bundled with C++ compiler and libraries. The software runs on Windows, Mac, and Linux and is free for personal/student use. The Qt Installation Guide has instructions for installing the tools onto your computer.
Getting Help
We want to enable everyone to succeed in this course and offer different paths to help.
The instructors and Head TA will hold weekly office hours. The section leaders staff LaIR helper hours. The CS106B Ed Discussion forum allows public Q&A and discussion with your peers. Here is the Quick Start Guide to using Ed.
Accommodations
Students who need an academic accommodation based on the impact of a disability should initiate a request with the Office of Accessible Education. Professional staff will evaluate the request with required documentation, recommend reasonable accommodations, and prepare an Accommodation Letter dated in the current quarter. Students should contact the OAE as soon as possible since timely notice is needed to coordinate accommodations. The OAE has contact information on their web page: http://oae.stanford.edu. Once you obtain your OAE letter, please use this form to submit it to the course staff.
Force Majeure
A note from the Center for Teaching and Learning:
Stanford as an institution is committed to the highest quality education, and as your teaching team, our first priority is to uphold your educational experience. To that end we are committed to following the syllabus as written here, including through short or long-term disruptions, such as public health emergencies, natural disasters, or protests and demonstrations. However, there may be extenuating circumstances that necessitate some changes. Should adjustments be necessary we will communicate clearly and promptly to ensure you understand the expectations and are positioned for successful learning.