This is an archive of whiteboarding problems discussed at weekly whiteboarding meetups at Noisebridge. Make a PR if you've written a solution. To pose an algorithm problem to the group, open an issue in this repository.
If you're new to whiteboarding, here's a miniature prerequisite roadmap to help prepare you for the experience:
- Learn programming fundamentals (variables, functions, loops, arrays, etc). Python is a popular language choice; however, most algorithm books use Java, C or C++, so exposure to one of those is recommended.
- Explore the basics of data structures and algorithms (big-O, stacks, queues, graphs, hashing, sorting, searching, etc).
- Grab a copy of Cracking the Coding Interview, read a few chapters and try some problems.
- Sign up for LeetCode and other coding challenge sites and keep solving!
- Please adhere to your language's typical style guidelines for indentation, whitespace and casing.
- Focus on realistic solutions to whiteboarding problems (cap lines of code at a reasonable amount but feel free to subtract lines used to write larger helper functions that an interviewer would typically allow to be abbreviated, like a disjoint-set).
- Add a simple test suite or driver code.
- Collect maximum points in a grid using two traversals (similar: Cherry Pickup)
- Largest time for given digits
- Reveal cards in increasing order
- Flip equivalent binary trees
- Design an elevator
- Given a sequence of points where consecutive points are connected by line segments to make a path, return the point along the path that corresponds to a given percentage along the path.
- Longest file path
- Write the most efficient data structure that stores the last N records of orders to a company that supports two operations: (1) Return the record for the ith last order and (2) add a new record for a new order.
- Write a post-order traversal of a binary tree using iteration
- Concurrent sum
- Force order in concurrency (Similar)
- Select a random number from a stream with O(1) space
- Find missing number in an array of N-1 elements where number from 1 to N is missing. (Similar)
- CTCI 17.24, Max Submatrix: Given an NxN matrix of positive and negative integers, write code to find the submatrix with the largest possible sum. Variant: submatrix is not necessarily square.
- Dependency resolution (Similar to CTCI 4.7)
- CTCI 2.5: Add two numbers stored in linked lists
- CTCI 2.3: Delete a node in the middle of a singly linked list, given only access to that node
- Regions cut by slashes
- Generate all binary strings of length n with k bits set
- Print all paths from top left to bottom right of an n by m matrix moving only right and down
- 2-sum, 3-sum, 4-sum and variants
- Encode and decode strings
- CTCI 1.1: Is unique
- CTCI 1.2: Check permutations
- CTCI 1.3: URLify
- CTCI 1.5: One away
- CTCI 1.6: String compression
- All possible full BSTs
- Range sum of BST
- Find itinerary (variant: return origin city)
- LRU cache
- CTCI 15.7: Multithreaded FizzBuzz
- CTCI 4.1: Routes between nodes
- Save the Queen!
- Balanced parenthesis
- Combine fruits
- Find and replace in string
- Word break
- Best time to buy and sell stock
- Decode String
- Binary parse trees
- Reverse Vowels in a String
- Valid parenthesis string
- Connected Cell in a Grid
- Longest palindromic substring
- Valid Perfect Square
- Product of Array Except Self
- Almost Sorted
- Find Peak Element
- CTCI 8.14 Boolean Evaluation
- Larry's Array
- Given a number
k
and an array of numbers, return an array of thek
largest elements in the array in any order. - String without AAA or BBB
- Shortest palindrome
- Find leftmost
1
in linear time in a matrix of1
and0
where each row is sorted ascending (all0
s are left of the1
s). - Write
rand5()
using onlyrand7()
- House Robber
- Largest Rectangle in Histogram
- Remove nth node in linked list
- Return deepest node in a binary tree
- Binary Search Tree Iterator
- Roll a string
- Hungry Rabbit in Garden of Carrots
- Median of binary search tree
- Find a path from top left to bottom right of a matrix
- Cousins in Binary Tree
- Word Ladder
- Sort floating point numbers by decimal portion of the number only
- Perfectly Balanced (follow-up: with wildcards)
- Spiral Matrix
- Rotting Oranges
- Array Manipulation
- Train of Dominoes
- CTCI 16.14 Best Line
- CTCI 16.19 Pond Sizes
- Score bowling
- Split a common address into parts
- Name matching
- CTCI 16.21 Sum Swap: Given two arrays of integers, find a pair of values (one value from each array) that you can swap to give the two arrays the same sum.
- Can you hop through an array of numbers from beginning to end? Each
a[i]
is the max potential step size.[1,2,0,1] => true
,[2,1,0,1] => false
. - Find a duplicate in an array containing numbers 1..N in O(n) time and O(1) space
- Trapping Rain Water
- Determine if a graph is a tree, and if it isn't, delete edges to make it into one.
- Magic list: longest consecutive list of words made by changing one letter, given a word list and a start letter.
- Make a bunch of separate API calls and return the results in an array.
- Array Manipulation