Programming Abstractions


Stanford School of Engineering



Gain valuable exposure to advanced computer programming and abstraction techniques. Become knowledgeable about the many implementation methods used to build complicated, dynamic data structures. Harness powerful tools for understanding how the representation and efficiency of data can influence how effectively we can store it.



Programming Methodology (Stanford Course: CS106A) or equivalent

Students coming to CS106B are expected to have substantial prior experience with programming constructs such as loops, functions/methods, arrays, console and file I/O, standard data types (integer, string, and floating point), and classes. In other words, students coming to CS106B are expected to know how to write code.

Topics include

  • Principles of data abstraction and modularity
  • Object-oriented programming, fundamental data structures and data-directed design
  • Recursion and recursive data structures (linked lists, trees, graphs)
  • Programming language C++ basics
  • Introduction to time and space complexity analysis

Note on Course Availability

The course schedule is displayed for planning purposes – courses can be modified, changed, or cancelled. Course availability will be considered finalized on the first day of open enrollment. For quarterly enrollment dates, please refer to our graduate certificate homepage.

049 Spring 2018-19 Online

Enroll Now

Dates:April 1 - June 5, 2019
Days: Mon, Wed, Fri
Times:2:30 pm - 3:20 pm
Units: 3.00-5.00
Instructors: Marty Stepp
Delivery Option:
For Credit $6,300.00 ?


Enrollment Dates: February 10 to March 18, 2019

Computer Science Department Requirement
Students taking graduate courses in Computer Science must enroll for the maximum number of units and maintain a B or better in each course in order to continue taking courses under the Non Degree Option.

This course may not currently be available to residents of certain states.