- Hash Tables
- ArrayList & Resizable Arrays
- StringBuilder
- Creating a Linked List
- Deleting a Node from a Singly Linked List
- The "Runner" Technique
- Recursive Problems
- Implementing a Stack
- Impelementing a Queue
- Types of Trees
- Binary Tree Traversal
- Binary Heaps ( Min-Heaps and Max-Heaps )
- Tries ( Prefix Trees )
- Graphs
- Graphs Search
- Bit Manipulation By Hand
- Bit Facts and Tricks
- Two's Complement and Negative Numbers
- Arithmetic vs. Logical Right Shift
- Common Bit Task: Getting and Setting
- Prime Numbers
- Probability
- Start Talking
- Develop Rules and Patterns
- Worst Case Shifting
- Algorithm Approaches
- How to Approach
- Design Patterns
- How to Approach
- Recursive vs. Iterative Solutions
- Dynamic Programming & Memoization
- Handling the Questions
- Design: Step-By-Step
- Algorithms that Scale: Step-By-Step
- Key Concepts
- Considerations
- There is no "perfect" system
- Example Problem
- What the Interviewer is looking for
- Testing a Real World Object
- Testing a Piece of Software
- Testing a Function
- Troubleshooting Questions