CS106B: Programming Abstractions (Stanford Univ.). Instructor: Professor Julie Zelenski. This course is the natural successor to Programming Methodology
and covers such advanced programming topics as recursion, algorithmic analysis, and data abstraction using the C++ programming language, which is similar to
both C and Java. Programming Abstractions assumes that you already have familiarity with good programming style and software engineering issues (at the level of Programming Methodology),
and that you can use this understanding as a foundation on which to tackle new topics in programming and data abstraction. Topics: Abstraction and its relation to programming.
Software engineering principles of data abstraction and modularity. Object-oriented programming, fundamental data structures (such as stacks, queues, sets) and data-directed design.
Recursion and recursive data structures (linked lists, trees, graphs). Introduction to time and space complexity analysis. Uses the programming language C++ covering its basic facilities.
(from see.stanford.edu)
Lecture 23 - Pathfinder Demo, Graphs: Explanation, Graph Representation in C++