diff --git a/contents/algorithms/array.md b/contents/algorithms/array.md index aebc2803..00d5c1eb 100644 --- a/contents/algorithms/array.md +++ b/contents/algorithms/array.md @@ -33,7 +33,7 @@ When you are given two arrays to process, it is common to have one index per arr - Sequence with 1 or 2 elements - Sequence with repeated elements -## Recommended Leetcode questions +## Recommended LeetCode questions - [Two Sum](https://leetcode.com/problems/two-sum/) - [Best Time to Buy and Sell Stock](https://leetcode.com/problems/best-time-to-buy-and-sell-stock/) @@ -45,57 +45,3 @@ When you are given two arrays to process, it is common to have one index per arr - [Search in Rotated Sorted Array](https://leetcode.com/problems/search-in-rotated-sorted-array/) - [3Sum](https://leetcode.com/problems/3sum/) - [Container With Most Water](https://leetcode.com/problems/container-with-most-water/) - -## More questions - -### Easy - -- Implement a circular buffer using an array. ([Solution](https://www.geeksforgeeks.org/circular-queue-set-1-introduction-array-implementation/)) -- Given an array of integers, print out a histogram using the said array; include a base layer (all stars) ([Solution](https://www.geeksforgeeks.org/program-make-histogram-array/)) -- Given an array and an index, find the product of the elements of the array except the element at that index. ([Solution](https://www.geeksforgeeks.org/a-product-array-puzzle/)) -- Given 2 separate arrays, write a method to find the values that exist in both arrays and return them. ([Solution](https://www.geeksforgeeks.org/union-and-intersection-of-two-sorted-arrays-2/)) -- Given an input array and another array that describes a new index for each element, mutate the input array so that each element ends up in their new index ([Solution](https://www.geeksforgeeks.org/reorder-a-array-according-to-given-indexes/)) - - Discuss the runtime of the algorithm and how you can be sure there would not be any infinite loops -- Given an array of non-negative numbers, find continuous subarray with sum to S. ([Solution 1](https://www.geeksforgeeks.org/find-subarray-with-given-sum/)) ([Solution 2](http://blog.gainlo.co/index.php/2016/06/01/subarray-with-given-sum/)) -- Given an array of numbers list out all triplets that sum to 0. Do so with a running time of less than O(n^3). ([Solution 1](https://www.geeksforgeeks.org/find-triplets-array-whose-sum-equal-zero/)) ([Solution 2](http://blog.gainlo.co/index.php/2016/07/19/3sum/)) -- Given an array of numbers list out all quadruplets that sum to 0. Do so with a running time of less than O(n^4). ([Solution](https://www.geeksforgeeks.org/find-four-numbers-with-sum-equal-to-given-sum/)) -- Given an array of integers, find the subarray with the largest sum. ([Solution](https://www.geeksforgeeks.org/largest-sum-contiguous-subarray/)) -- Find the second maximum value in an array. ([Solution](https://www.geeksforgeeks.org/find-second-largest-element-array/)) -- Rotate an array by an offset of k. ([Solution](https://www.geeksforgeeks.org/array-rotation/)) -- Remove duplicates in an unsorted array where the duplicates are at a distance of k or less from each other. ([Solution](https://www.geeksforgeeks.org/check-given-array-contains-duplicate-elements-within-k-distance/)) -- Given an unsorted list of integers, return true if the list contains any duplicates within k indices of each element. Do it faster than O(n^2). ([Solution](https://www.geeksforgeeks.org/check-given-array-contains-duplicate-elements-within-k-distance/)) - - Given an unsorted list of integers, return true if the list contains any fuzzy duplicates within k indices of each element. A fuzzy duplicate is another integer within d of the original integer. Do it faster than O(n^2). - - E.g. If d = 4, then 6 is a fuzzy duplicate of 3 but 8 is not. -- Say you have an unordered list of numbers ranging from 1 to n, and one of the numbers is removed, how do you find that number? What if two numbers are removed? ([Solution](https://www.geeksforgeeks.org/find-the-missing-number/)) -- Given an array of string, find the duplicated elements. ([Solution 1](https://www.geeksforgeeks.org/find-duplicates-in-on-time-and-constant-extra-space/)) ([Solution 2](http://blog.gainlo.co/index.php/2016/05/10/duplicate-elements-of-an-array/)) -- Given an array of integers, find a maximum sum of non-adjacent elements. ([Solution 1](https://www.geeksforgeeks.org/maximum-sum-such-that-no-two-elements-are-adjacent/)) ([Solution 2](http://blog.gainlo.co/index.php/2016/12/02/uber-interview-question-maximum-sum-non-adjacent-elements/)) - - E.g. `[1, 0, 3, 9, 2]` should return `10 (1 + 9)`. -- Given an array of integers, modify the array by moving all the zeroes to the end (right side). The order of other elements doesn't matter. ([Solution 1](https://www.geeksforgeeks.org/move-zeroes-end-array/)) ([Solution 2](http://blog.gainlo.co/index.php/2016/11/18/uber-interview-question-move-zeroes/)) - - E.g. `[1, 2, 0, 3, 0, 1, 2]`, the program can output `[1, 2, 3, 1, 2, 0, 0]`. -- Given an array, return the length of the longest increasing contiguous subarray. ([Solution 1](https://www.geeksforgeeks.org/longest-increasing-subarray/)) ([Solution 2](http://blog.gainlo.co/index.php/2017/02/02/uber-interview-questions-longest-increasing-subarray/)) - - E.g., `[1, 3, 2, 3, 4, 8, 7, 9]`, should return `4` because the longest increasing array is `[2, 3, 4, 8]` -- Given an array of integers where every value appears twice except one, find the single, non-repeating value. Follow up: do so with O(1) space. ([Solution](https://www.geeksforgeeks.org/find-element-appears-array-every-element-appears-twice/)) - - E.g., `[2, 5, 3, 2, 1, 3, 4, 5, 1]` returns 4, because it is the only value that appears in the array only once. - -### Medium - -- Given a list of item prices, find all possible combinations of items that sum a particular value `K`. ([Solution](https://www.geeksforgeeks.org/combinational-sum/)) -- Given an array of integers find whether there is a sub-sequence that sums to 0 and return it. ([Solution](https://www.geeksforgeeks.org/find-if-there-is-a-subarray-with-0-sum/)) - - E.g. `[1, 2, -3, 1]` => `[1, 2, -3]` or `[2, -3, 1]` -- Trapping rain water: You have an array with the heights of an island (at point 1, point 2 etc) and you want to know how much water would remain on this island (without flowing away). ([Solution](https://www.geeksforgeeks.org/trapping-rain-water/)) - -### Hard - -- Given a set of rectangles represented by a height and an interval along the y-axis, determine the size of its union. ([Solution](https://www.geeksforgeeks.org/divide-and-conquer-set-7-the-skyline-problem/)) -- Given an array, find the longest arithmetic progression. ([Solution](https://www.geeksforgeeks.org/longest-arithmetic-progression-dp-35/)) -- Given an unsorted array of integers, find the length of the longest consecutive elements sequence. - - E.g. `[100, 4, 200, 1, 3, 2] => 4`. Explanation: The longest consecutive elements sequence is `[1, 2, 3, 4]`. Therefore its length is 4. Note: Your algorithm should run in O(n) complexity. ([Solution](https://www.geeksforgeeks.org/longest-consecutive-subsequence/)) - -### Other - -- In an array of arrays, e.g. given `[[], [1, 2, 3], [4, 5], [], [], [6, 7], [8], [9, 10], [], []]`, print: `1, 2, 3, 4, 5, 6, 7, 8, 9, 10`. - - Implement an iterator that supports `hasNext()`, `next()` and `remove()` methods. -- Paginate an array with constraints, such as skipping certain items. -- Given array of arrays, sort them in ascending order. -- Given an array containing only digits `0-9`, add one to the number and return the array. - - E.g. Given `[1, 4, 2, 1]` which represents `1421`, return `[1, 4, 2, 2]` which represents `1422`. diff --git a/contents/algorithms/binary.md b/contents/algorithms/binary.md index 14711da4..741d8aa3 100644 --- a/contents/algorithms/binary.md +++ b/contents/algorithms/binary.md @@ -24,17 +24,10 @@ Some helpful utility snippets: - Be aware and check for overflow/underflow - Negative numbers -## Recommended Leetcode questions +## Recommended LeetCode questions - [Sum of Two Integers](https://leetcode.com/problems/sum-of-two-integers/) - [Number of 1 Bits](https://leetcode.com/problems/number-of-1-bits/) - [Counting Bits](https://leetcode.com/problems/counting-bits/) - [Missing Number](https://leetcode.com/problems/missing-number/) - [Reverse Bits](https://leetcode.com/problems/reverse-bits/) - -## More questions - -- How do you verify if an integer is a power of 2? -- Write a program to print the binary representation of an integer. -- Write a program to print out the number of 1 bits in a given integer. -- Write a program to determine the largest possible integer using the same number of 1 bits in a given number. diff --git a/contents/algorithms/dynamic-programming.md b/contents/algorithms/dynamic-programming.md index b6126a96..d8879fe3 100644 --- a/contents/algorithms/dynamic-programming.md +++ b/contents/algorithms/dynamic-programming.md @@ -14,7 +14,7 @@ Dynamic Programming (DP) is usually used to solve optimization problems. The onl Sometimes you do not need to store the whole DP table in memory, the last two values or the last two rows of the matrix will suffice. -## Recommended Leetcode questions +## Recommended LeetCode questions - 0/1 Knapsack - [Climbing Stairs](https://leetcode.com/problems/climbing-stairs/) @@ -27,33 +27,3 @@ Sometimes you do not need to store the whole DP table in memory, the last two va - [Decode Ways](https://leetcode.com/problems/decode-ways/) - [Unique Paths](https://leetcode.com/problems/unique-paths/) - [Jump Game](https://leetcode.com/problems/jump-game/) - -## More questions - -- Given a flight itinerary consisting of starting city, destination city, and ticket price (2D list) - find the optimal price flight path to get from start to destination. (A variation of Dynamic Programming Shortest Path) -- Given some coin denominations and a target value `M`, return the coins combination with the minimum number of coins. - - Time complexity: `O(MN)`, where N is the number of distinct type of coins. - - Space complexity: `O(M)`. -- Given a set of numbers in an array which represent a number of consecutive days of Airbnb reservation requested, as a host, pick the sequence which maximizes the number of days of occupancy, at the same time, leaving at least a 1-day gap in-between bookings for cleaning. - - - The problem reduces to finding the maximum sum of non-consecutive array elements. - - E.g. - - ``` - // [5, 1, 1, 5] => 10 - The above array would represent an example booking period as follows - - // Dec 1 - 5 - // Dec 5 - 6 - // Dec 6 - 7 - // Dec 7 - 12 - - The answer would be to pick Dec 1-5 (5 days) and then pick Dec 7-12 for a total of 10 days of - occupancy, at the same time, leaving at least 1-day gap for cleaning between reservations. - - Similarly, - // [3, 6, 4] => 7 - // [4, 10, 3, 1, 5] => 15 - ``` - -- Given a list of denominations (e.g., `[1, 2, 5]` means you have coins worth $1, $2, and \$5) and a target number `k`, find all possible combinations, if any, of coins in the given denominations that add up to `k`. You can use coins of the same denomination more than once. -- You are climbing a flight of stairs. It takes n steps to reach to the top. Each time you can either climb 1 or 2 steps. In how many distinct ways can you climb to the top? E.g. Input: 3, Output: 3. Explanation: `[1, 1, 1], [1, 2], [2, 1]`. diff --git a/contents/algorithms/geometry.md b/contents/algorithms/geometry.md index 16814bca..29da24f4 100644 --- a/contents/algorithms/geometry.md +++ b/contents/algorithms/geometry.md @@ -9,7 +9,7 @@ When comparing euclidean distance between two pairs of points, using dx2 `false` - - E.g. `[1, 4]` and `[3, 6]` => `true` - - Given 2 interval ranges that intersect, now create a function to merge the 2 ranges into a single continuous range. - - E.g. `[1, 4]` and `[3, 6]` => `[1, 6]` - - Now create a function that takes a group of unsorted, unorganized intervals, merge any intervals that intersect and sort them. The result should be a group of sorted, non-intersecting intervals. - - Now create a function to merge a new interval into a group of sorted, non-intersecting intervals. After the merge, all intervals should remain non-intersecting. -- Given a list of meeting times, check if any of them overlap. The follow-up question is to return the minimum number of rooms required to accommodate all the meetings. - - [Source](http://blog.gainlo.co/index.php/2016/07/12/meeting-room-scheduling-problem/) -- If you have a list of intervals, how would you merge them? - - E.g. `[1, 3], [8, 11], [2, 6]` => `[1, 6], [8-11]` +- [Meeting Rooms (LeetCode Premium)](https://leetcode.com/problems/meeting-rooms/) and [Meeting Rooms II (LeetCode Premium)](https://leetcode.com/problems/meeting-rooms-ii/) diff --git a/contents/algorithms/linked-list.md b/contents/algorithms/linked-list.md index 64974ef6..f369172c 100644 --- a/contents/algorithms/linked-list.md +++ b/contents/algorithms/linked-list.md @@ -38,7 +38,7 @@ Be familiar with the following routines because many linked list questions make - Two nodes - Linked list has cycle. **Tip:** Clarify with the interviewer whether there can be a cycle in the list. Usually the answer is no -## Recommended Leetcode questions +## Recommended LeetCode questions - [Reverse a Linked List](https://leetcode.com/problems/reverse-linked-list/) - [Detect Cycle in a Linked List](https://leetcode.com/problems/linked-list-cycle/) @@ -46,15 +46,3 @@ Be familiar with the following routines because many linked list questions make - [Merge K Sorted Lists](https://leetcode.com/problems/merge-k-sorted-lists/) - [Remove Nth Node From End Of List](https://leetcode.com/problems/remove-nth-node-from-end-of-list/) - [Reorder List](https://leetcode.com/problems/reorder-list/) - -## More questions - -- Given a linked list, in addition to the next pointer, each node has a child pointer that can point to a separate list. With the head node, flatten the list to a single-level linked list. - - [Source](http://blog.gainlo.co/index.php/2016/06/12/flatten-a-linked-list/) -- Reverse a singly linked list. Implement it recursively and iteratively. -- Convert a binary tree to a doubly circular linked list. -- Implement an LRU cache with O(1) runtime for all its operations. -- Check distance between values in linked list. -- A question involving an API's integration with hash map where the buckets of hash map are made up of linked lists. -- Given a singly linked list (a list which can only be traversed in one direction), find the item that is located at 'k' items from the end. So if the list is a, b, c, d and k is 2 then the answer is 'c'. The solution should not search the list twice. -- How can you tell if a Linked List is a Palindrome? diff --git a/contents/algorithms/math.md b/contents/algorithms/math.md index 76cfe106..f3a05c15 100644 --- a/contents/algorithms/math.md +++ b/contents/algorithms/math.md @@ -22,28 +22,8 @@ If the question asks to implement an operator such as power, squareroot or divis - Permutations of N = N! / (N-K)! - Combinations of N = N! / (K! \* (N-K)!) -## Recommended Leetcode questions +## Recommended LeetCode questions - [Pow(x, n)](https://leetcode.com/problems/powx-n/) - [Sqrt(x)](https://leetcode.com/problems/sqrtx/) - [Integer to English Words](https://leetcode.com/problems/integer-to-english-words/) - -## More questions - -- Create a square root function. -- Given a string such as "123" or "67", write a function to output the number represented by the string without using casting. -- Make a program that can print out the text form of numbers from 1 - 1000 (ex. 20 is "twenty", 105 is "one hundred and five"). -- Write a function that parses Roman numerals. - - E.g. `XIV` returns `14`. -- Write in words for a given digit. - - E.g. `123` returns `one hundred and twenty three`. -- Given a number `N`, find the largest number just smaller than `N` that can be formed using the same digits as `N`. -- Compute the square root of `N` without using any existing functions. -- Given numbers represented as binary strings, and return the string containing their sum. - - E.g. `add('10010', '101')` returns `'10111'`. -- Take in an integer and return its english word-format. - - E.g. 1 -> "one", -10,203 -> "negative ten thousand two hundred and three". -- Write a function that returns values randomly, according to their weight. Suppose we have 3 elements with their weights: A (1), B (1) and C (2). The function should return A with probability 25%, B with 25% and C with 50% based on the weights. - - [Source](http://blog.gainlo.co/index.php/2016/11/11/uber-interview-question-weighted-random-numbers/) -- Given a number, how can you get the next greater number with the same set of digits? - - [Source](http://blog.gainlo.co/index.php/2017/01/20/arrange-given-numbers-to-form-the-biggest-number-possible/) diff --git a/contents/algorithms/matrix.md b/contents/algorithms/matrix.md index acd3f70f..5df0b308 100644 --- a/contents/algorithms/matrix.md +++ b/contents/algorithms/matrix.md @@ -28,27 +28,9 @@ transposed_matrix = zip(*matrix) - 1 x 1 matrix - Matrix with only one row or column -## Recommended Leetcode questions +## Recommended LeetCode questions - [Set Matrix Zeroes](https://leetcode.com/problems/set-matrix-zeroes/) - [Spiral Matrix](https://leetcode.com/problems/spiral-matrix/) - [Rotate Image](https://leetcode.com/problems/rotate-image/) - [Word Search](https://leetcode.com/problems/word-search/) - -## More questions - -- You're given a 3 x 3 board of a tile puzzle, with 8 tiles numbered 1 to 8, and an empty spot. You can move any tile adjacent to the empty spot, to the empty spot, creating an empty spot where the tile originally was. The goal is to find a series of moves that will solve the board, i.e. get `[[1, 2, 3], [4, 5, 6], [7, 8, - ]]` where - is the empty tile. -- Boggle implementation. Given a dictionary, and a matrix of letters, find all the words in the matrix that are in the dictionary. You can go across, down or diagonally. -- The values of the matrix will represent numbers of carrots available to the rabbit in each square of the garden. If the garden does not have an exact center, the rabbit should start in the square closest to the center with the highest carrot count. On a given turn, the rabbit will eat the carrots available on the square that it is on, and then move up, down, left, or right, choosing the square that has the most carrots. If there are no carrots left on any of the adjacent squares, the rabbit will go to sleep. You may assume that the rabbit will never have to choose between two squares with the same number of carrots. Write a function which takes a garden matrix and returns the number of carrots the rabbit eats. You may assume the matrix is rectangular with at least 1 row and 1 column, and that it is populated with non-negative integers. For example, - - Example: `[[5, 7, 8, 6, 3], [0, 0, 7, 0, 4], [4, 6, 3, 4, 9], [3, 1, 0, 5, 8]]` should return `27`. -- Print a matrix in a spiral fashion. -- In the Game of life, calculate how to compute the next state of the board. Follow up was to do it if there were memory constraints (board represented by a 1 TB file). -- Grid Illumination: Given an NxN grid with an array of lamp coordinates. Each lamp provides illumination to every square on their x axis, every square on their y axis, and every square that lies in their diagonal (think of a Queen in chess). Given an array of query coordinates, determine whether that point is illuminated or not. The catch is when checking a query all lamps adjacent to, or on, that query get turned off. The ranges for the variables/arrays were about: 10^3 < N < 10^9, 10^3 < lamps < 10^9, 10^3 < queries < 10^9. -- You are given a matrix of integers. Modify the matrix such that if a row or column contains a 0, make the values in the entire row or column 0. -- Given an N x N matrix filled randomly with different colors (no limit on what the colors are), find the total number of groups of each color - a group consists of adjacent cells of the same color touching each other. -- You have a 4 x 4 board with characters. You need to write a function that finds if a certain word exists in the board. You can only jump to neighboring characters (including diagonally adjacent). -- Count the number of islands in a binary matrix of 0's and 1's. -- Check a 6 x 7 Connect 4 board for a winning condition. -- Given a fully-filled Sudoku board, check whether fulfills the Sudoku condition. -- Implement a function that checks if a player has won tic-tac-toe. -- Given an N x N matrix of 1's and 0's, figure out if all of the 1's are connected. diff --git a/contents/algorithms/oop.md b/contents/algorithms/oop.md index 4652375a..2117786a 100644 --- a/contents/algorithms/oop.md +++ b/contents/algorithms/oop.md @@ -3,7 +3,7 @@ id: oop title: Object-Oriented Programming --- -## More questions +## Sample questions - How would you design a chess game? What classes and objects would you use? What methods would they have? - How would you design the data structures for a book keeping system for a library? diff --git a/contents/algorithms/permutation.md b/contents/algorithms/permutation.md index 7579f511..9e6051e7 100644 --- a/contents/algorithms/permutation.md +++ b/contents/algorithms/permutation.md @@ -3,7 +3,7 @@ id: permutation title: Permutation --- -## More questions +## Sample questions - You are given a 7 digit phone number, and you should find all possible letter combinations based on the digit-to-letter mapping on numeric pad and return only the ones that have valid match against a given dictionary of words. - Give all possible letter combinations from a phone number. diff --git a/contents/algorithms/queue.md b/contents/algorithms/queue.md index eee3a100..0f412848 100644 --- a/contents/algorithms/queue.md +++ b/contents/algorithms/queue.md @@ -3,7 +3,7 @@ id: queue title: Queue --- -## More questions +## Sample questions - Implement a Queue class from scratch with an existing bug, the bug is that it cannot take more than 5 elements. - Implement a Queue using two stacks. You may only use the standard `push()`, `pop()`, and `peek()` operations traditionally available to stacks. You do not need to implement the stack yourself (i.e. an array can be used to simulate a stack). diff --git a/contents/algorithms/recursion.md b/contents/algorithms/recursion.md index 88843fc3..378da71d 100644 --- a/contents/algorithms/recursion.md +++ b/contents/algorithms/recursion.md @@ -11,7 +11,7 @@ Remember to always define a base case so that your recursion will end. Recursion implicitly uses a stack. Hence all recursive approaches can be rewritten iteratively using a stack. Beware of cases where the recursion level goes too deep and causes a stack overflow (the default limit in Python is 1000). You may get bonus points for pointing this out to the interviewer. Recursion will never be O(1) space complexity because a stack is involved, unless there is [tail-call optimization](https://stackoverflow.com/questions/310974/what-is-tail-call-optimization) (TCO). Find out if your chosen language supports TCO. -## Recommended Leetcode questions +## Recommended LeetCode questions - [Subsets](https://leetcode.com/problems/subsets/) and [Subsets II](https://leetcode.com/problems/subsets-ii/) -- [Strobogrammatic Number II (Leetcode Premium)](https://leetcode.com/problems/strobogrammatic-number-ii/) +- [Strobogrammatic Number II (LeetCode Premium)](https://leetcode.com/problems/strobogrammatic-number-ii/) diff --git a/contents/algorithms/sorting-searching.md b/contents/algorithms/sorting-searching.md index 34384011..ddbea156 100644 --- a/contents/algorithms/sorting-searching.md +++ b/contents/algorithms/sorting-searching.md @@ -3,7 +3,7 @@ id: sorting-searching title: Sorting and Searching --- -## More questions +## Sample questions - Sorting search results on a page given a certain set of criteria. - Sort a list of numbers in which each number is at a distance `K` from its actual position. diff --git a/contents/algorithms/stack.md b/contents/algorithms/stack.md index 1ed52241..8262a74c 100644 --- a/contents/algorithms/stack.md +++ b/contents/algorithms/stack.md @@ -3,7 +3,7 @@ id: stack title: Stack --- -## More questions +## Sample questions - Implementation of an interpreter for a small language that does multiplication/addition/etc. - Design a `MinStack` data structure that supports a `min()` operation that returns the minimum value in the stack in O(1) time. diff --git a/contents/algorithms/string.md b/contents/algorithms/string.md index 849493ed..e7abcb35 100644 --- a/contents/algorithms/string.md +++ b/contents/algorithms/string.md @@ -86,7 +86,7 @@ When a question is about counting the number of palindromes, a common trick is t - String with repeated characters - Strings with only one distinct character -## Recommended Leetcode questions +## Recommended LeetCode questions - [Longest Substring Without Repeating Characters](https://leetcode.com/problems/longest-substring-without-repeating-characters/) - [Longest Repeating Character Replacement](https://leetcode.com/problems/longest-repeating-character-replacement/) @@ -97,61 +97,4 @@ When a question is about counting the number of palindromes, a common trick is t - [Valid Palindrome](https://leetcode.com/problems/valid-palindrome/) - [Longest Palindromic Substring](https://leetcode.com/problems/longest-palindromic-substring/) - [Palindromic Substrings](https://leetcode.com/problems/palindromic-substrings/) -- [Encode and Decode Strings (Leetcode Premium)](https://leetcode.com/problems/encode-and-decode-strings/) - -## More questions - -- Output list of strings representing a page of hostings given a list of CSV strings. -- Given a list of words, find the word pairs that when concatenated form a palindrome. -- Find the most efficient way to identify what character is out of place in a non-palindrome. -- Implement a simple regex parser which, given a string and a pattern, returns a boolean indicating whether the input matches the pattern. By simple, we mean that the regex can only contain the following special characters: `*` (star), `.` (dot), `+` (plus). The star means that there will be zero or more of the previous character in that place in the pattern. The dot means any character for that position. The plus means one or more of previous character in that place in the pattern. -- Find all words from a dictionary that are x edit distance away. -- Given a string IP and number n, print all CIDR addresses that cover that range. -- Write a function called `eval`, which takes a string and returns a boolean. This string is allowed 6 different characters: `0`, `1`, `&`, `|`, `(`, and `)`. `eval` should evaluate the string as a boolean expression, where `0` is `false`, `1` is `true`, `&` is an `and`, and `|` is an `or`. - - E.g `"(0 | (1 | 0)) & (1 & ((1 | 0) & 0))"` -- Given a pattern string like `"abba"` and an input string like `"redbluebluered"`, return `true` if and only if there's a one to one mapping of letters in the pattern to substrings of the input. - - E.g. `"abba"` and `"redbluebluered"` should return `true`. - - E.g. `"aaaa"` and `"asdasdasdasd"` should return `true`. - - E.g. `"aabb"` and `"xyzabcxzyabc"` should return `false`. -- If you received a file in chunks, calculate when you have the full file. Quite an open-ended question. Can assume chunks come with start and end, or size, etc. -- Given a list of names (strings) and the width of a line, design an algorithm to display them using the minimum number of lines. -- Design a spell-checking algorithm. -- Longest substring with `K` unique characters. - - [Source](http://blog.gainlo.co/index.php/2016/04/12/find-the-longest-substring-with-k-unique-characters/) -- Given a set of random strings, write a function that returns a set that groups all the anagrams together. - - [Source](http://blog.gainlo.co/index.php/2016/05/06/group-anagrams/) -- Given a string, find the longest substring without repeating characters. For example, for string `'abccdefgh'`, the longest substring is `'cdefgh'`. - - [Source](http://blog.gainlo.co/index.php/2016/10/07/facebook-interview-longest-substring-without-repeating-characters/) -- Given a string, return the string with duplicate characters removed. -- Write a function that receives a regular expression (allowed chars = from `'a'` to `'z'`, `'*'`, `'.'`) and a string containing lower case english alphabet characters and return `true` or `false` whether the string matches the regex. - - E.g. `'ab*a'`, `'abbbbba'` => `true`. - - E.g. `'ab*b.'`, `'aba'` => `true`. - - E.g. `'abc*'`, `'acccc'` => `false`. -- Given a rectangular grid with letters, search if some word is in the grid. -- Given two strings representing integer numbers (`'123'` , `'30'`) return a string representing the sum of the two numbers: `'153'`. -- A professor wants to see if two students have cheated when writing a paper. Design a function `hasCheated(String s1, String s2, int N)` that evaluates to `true` if two strings have a common substring of length `N`. - - Follow up: Assume you don't have the possibility of using `String.contains()` and `String.substring()`. How would you implement this? -- Print all permutations of a given string. -- Parse a string containing numbers and `'+'`, `'-'` and parentheses. Evaluate the expression. `-2+(3-5)` should return `-4`. -- Output a substring with at most `K` unique characters. - - E.g. `'aabc'` and `k` = 2 => `'aab'`. -- Ensure that there are a minimum of `N` dashes between any two of the same characters of a string. - - E.g. `n = 2, string = 'ab-bcdecca'` => `'ab--bcdec--ca'`. -- Find the longest palindrome in a string. -- Give the count and the number following in the series. - - E.g. `1122344`, next: `21221324`, next: `12112211121214`. - - Count and say problem. -- Compress a string by grouping consecutive similar questions together: - - E.g. `'aaabbbcc' =>`'a3b3c2'`. -- You have a string consisting of open and closed parentheses, but parentheses may be imbalanced. Make the parentheses balanced and return the new string. -- Given a set of strings, return the smallest subset that contains prefixes for every string. - - E.g. `['foo', 'foog', 'food', 'asdf']` => `['foo', 'asdf']`. -- Write a function that would return all the possible words generated when using a phone (pre-smartphone era) numpad to type. -- Given a dictionary and a word, find the minimum number of deletions needed on the word in order to make it a valid word. - - [Source](http://blog.gainlo.co/index.php/2016/04/29/minimum-number-of-deletions-of-a-string/) -- How to check if a string contains an anagram of another string? - - [Source](http://blog.gainlo.co/index.php/2016/04/08/if-a-string-contains-an-anagram-of-another-string/) -- Find all k-lettered words from a string. -- Given a string of open and close parentheses, find the minimum number of edits needed to balance a string of parentheses. -- Run length encoding - Write a string compress function that returns `'R2G1B1'` given `'RRGB'`. -- Write a function that finds all the different ways you can split up a word into a concatenation of two other words. +- [Encode and Decode Strings (LeetCode Premium)](https://leetcode.com/problems/encode-and-decode-strings/) diff --git a/contents/algorithms/tree.md b/contents/algorithms/tree.md index 8f73ebb3..5df7cdda 100644 --- a/contents/algorithms/tree.md +++ b/contents/algorithms/tree.md @@ -46,7 +46,7 @@ Be very familiar with the properties of a BST and validating that a binary tree When a question involves a BST, the interviewer is usually looking for a solution which runs faster than O(n). -#### Recommended Leetcode questions +#### Recommended LeetCode questions - [Maximum Depth of Binary Tree](https://leetcode.com/problems/maximum-depth-of-binary-tree/) - [Same Tree](https://leetcode.com/problems/same-tree/) @@ -59,39 +59,3 @@ When a question involves a BST, the interviewer is usually looking for a solutio - [Validate Binary Search Tree](https://leetcode.com/problems/validate-binary-search-tree/) - [Kth Smallest Element in a BST](https://leetcode.com/problems/kth-smallest-element-in-a-bst/) - [Lowest Common Ancestor of BST](https://leetcode.com/problems/lowest-common-ancestor-of-a-binary-search-tree/) - -## More questions - -- Find the height of a tree. -- Find the longest path from the root to leaf in a tree. -- Find the deepest left leaf of a tree. -- Print all paths of a binary tree. - - [Source](http://blog.gainlo.co/index.php/2016/04/15/print-all-paths-of-a-binary-tree/) -- Second largest element of a BST. - - [Source](http://blog.gainlo.co/index.php/2016/06/03/second-largest-element-of-a-binary-search-tree/) -- Given a binary tree and two nodes, how to find the common ancestor of the two nodes? - - [Source](http://blog.gainlo.co/index.php/2016/07/06/lowest-common-ancestor/) -- Find the lowest common ancestor of two nodes in a binary search tree. -- Print the nodes in an n-ary tree level by level, one printed line per level. -- Given a directory of files and folders (and relevant functions), how would you parse through it to find equivalent files? -- Write a basic file system and implement the commands ls, pwd, mkdir, create, rm, cd, cat, mv. -- Compute the intersection of two binary search trees. -- Given a binary tree, output all the node to leaf paths of it. -- Given a string of characters without spaces, is there a way to break the string into valid words without leftover characters? -- Print a binary tree level by level. -- Determine if a binary tree is "complete" (i.e, if all leaf nodes were either at the maximum depth or max depth-1, and were 'pressed' along the left side of the tree). -- Find the longest path in a binary tree. The path may start and end at any node. -- Determine if a binary tree is a BST. -- Given a binary tree, serialize it into a string. Then deserialize it. -- Print a binary tree by column. -- Given a node, find the next element in a BST. -- Find the shortest subtree that consist of all the deepest nodes. The tree is not binary. -- Print out the sum of each row in a binary tree. -- Pretty print a JSON object. -- Convert a binary tree to a doubly circular linked list. -- Find the second largest number in a binary tree. -- Given a tree, find the longest branch. -- Convert a tree to a linked list. -- Given two trees, write code to find out if tree A is a subtree of tree B. -- Deepest node in a tree. - - [Source](http://blog.gainlo.co/index.php/2016/04/26/deepest-node-in-a-tree/) diff --git a/contents/algorithms/trie.md b/contents/algorithms/trie.md index 239b2c79..01fbf652 100644 --- a/contents/algorithms/trie.md +++ b/contents/algorithms/trie.md @@ -16,7 +16,7 @@ Sometimes preprocessing a dictionary of words (given in a list) into a trie, wil Be familiar with implementing, from scratch, a `Trie` class and its `add`, `remove` and `search` methods. -## Recommended Leetcode questions +## Recommended LeetCode questions - [Implement Trie (Prefix Tree)](https://leetcode.com/problems/implement-trie-prefix-tree) - [Add and Search Word](https://leetcode.com/problems/add-and-search-word-data-structure-design) diff --git a/contents/best-practice-questions.md b/contents/best-practice-questions.md index f5d965dd..f0573ba8 100644 --- a/contents/best-practice-questions.md +++ b/contents/best-practice-questions.md @@ -62,7 +62,7 @@ The focus of week 3 is on non-linear data structures like trees, graphs and heap - [Maximum Depth of Binary Tree](https://leetcode.com/problems/maximum-depth-of-binary-tree/) - [Same Tree](https://leetcode.com/problems/same-tree/) - [Binary Tree Level Order Traversal](https://leetcode.com/problems/binary-tree-level-order-traversal/) -- [Encode and Decode Strings (Leetcode Premium)](https://leetcode.com/problems/encode-and-decode-strings/) +- [Encode and Decode Strings (LeetCode Premium)](https://leetcode.com/problems/encode-and-decode-strings/) ## Week 4 - More Data Structures @@ -81,11 +81,11 @@ Week 4 builds up on knowledge from previous weeks but questions are of increased #### Optional -- [Meeting Rooms (Leetcode Premium)](https://leetcode.com/problems/meeting-rooms/) -- [Meeting Rooms II (Leetcode Premium)](https://leetcode.com/problems/meeting-rooms-ii/) -- [Alien Dictionary (Leetcode Premium)](https://leetcode.com/problems/alien-dictionary/) -- [Graph Valid Tree (Leetcode Premium)](https://leetcode.com/problems/graph-valid-tree/) -- [Number of Connected Components in an Undirected Graph (Leetcode Premium)](https://leetcode.com/problems/number-of-connected-components-in-an-undirected-graph/) +- [Meeting Rooms (LeetCode Premium)](https://leetcode.com/problems/meeting-rooms/) +- [Meeting Rooms II (LeetCode Premium)](https://leetcode.com/problems/meeting-rooms-ii/) +- [Alien Dictionary (LeetCode Premium)](https://leetcode.com/problems/alien-dictionary/) +- [Graph Valid Tree (LeetCode Premium)](https://leetcode.com/problems/graph-valid-tree/) +- [Number of Connected Components in an Undirected Graph (LeetCode Premium)](https://leetcode.com/problems/number-of-connected-components-in-an-undirected-graph/) ## Week 5 - Dynamic Programming