# Top LeetCode Patterns for FAANG Coding Interviews

Coding patterns enhance our “ability to map a new problem to an already known problem."

Preparing for programming interviews can be made easier by focusing on coding patterns.

Every software engineer should learn problem-solving patterns such as Sliding Window, Two Pointers, Two Heaps, etc. By doing so, software engineers will be able to develop the skill of “mapping a new problem to an existing one.” Following these common patterns also makes interview preparation a streamlined process.

In this post, we will learn which common patterns have the highest return on investment for software engineers.

Grokking the Coding Interview from Design Gurus came up with a list of 20 patterns for coding questions based on the similarities in the techniques needed to solve them. The course’s idea is to teach famous Leetcode interview patterns so that once someone is familiar with a pattern, they will be able to solve dozens of problems with it.

## LeetCode Problems Distribution

LeetCode (LC), being the largest repository of coding problems, contains more than 2k+ questions. Each question on LC can be tagged with one or more topics. These topics are either data structures like Array, HashTable, Tree, etc., or algorithmic techniques like Greedy, Divide and Conquer, Sorting, etc., or coding patterns like Sliding Window, Depth First Search, Topological Sort, etc.

Here is the topic distribution for LC questions:

The top topic is Array with 1142 problems, followed by String with 549 problems, and so on. Let’s take a closer look at each category of topics, namely Data Structures, Algorithms, and Coding Patterns.

## Top Data Structures with the Best ROI

Here are the top Data Structures with the highest return on investment:

1. Array (1142 problems)
2. String (549)
3. Hash Table (392)
4. Tree (191)
5. Matrix (171)
6. Stack (128)
7. Heap or Priority Queue (107)
8. Graph (102)
9. Linked List (69)
10. Trie (44)

## Top Algorithmic Techniques with the Best ROI

Here are the top common algorithms techniques with the highest return on investment:

1. Dynamic Programming (383)
2. Sorting (253)
3. Greedy (248)
4. Binary Search (186)
5. Backtracking (91)
6. Recursion (44)
7. Divide and Conquer (38)

## Top Coding Patterns with the Best ROI

Here are the top coding patterns with the highest return on investment:

1. Depth First Search (250)
2. Breadth First Search(198)
3. Binary Search (186)
4. Two Pointers (147)
5. Sliding Window (72)
6. Monotonic Stack (44)
7. Union Find (63)
8. Memoization (32)
9. Topological Sort (28)
10. Segment Tree (27)

## Best Coding Patterns with Highest ROI

Combining all categories from the above data, here is the list of best coding patterns/techniques with the highest ROI:

1. Two Pointers (Arrays, Strings, Fast & Slow Pointer)
This pattern covers a huge set of questions related to Arrays and Strings, which are the highest tagged data structures. Fast & Slow Pointer can be easily understood as a variation of the Two Pointers pattern.

2. Sliding Window (Arrays, Strings, Hash Tables)
Sliding Window covers most of the problems related to top data structures like Arrays, Strings, and HashTables.

3. Tree and Graph Depth First Search (Matrix Traversal)
Most Trees and Graphs problems can be solved using Depth First Search (DFS). Matrix Traversal, which is also DFS based pattern, covers most of the matrix-related problems.

4. Tree and Graph Breadth First Search (Queue, Subsets, Matrix Traversal, Topological Sort)
Breadth First Search (BFS) is a very handy pattern. BFS’s patterns like Subsets, Matrix Traversal, and Topological Sort cover a good number of problems.

5. Binary Search (Arrays)
Binary Search and its variants are used to solve a huge number of coding questions.

6. Interval Merge
Although there are not many problems related to Interval Merge, these problems frequently appear in coding interviews.

7. Recursion/Backtracking
Backtracking and recursion are used to solve a wide range of problems. Mastering these techniques is highly recommended.

For an extensive list, here are other common patterns that you should look into if you are preparing for software engineering interviews:

1. K-way Merge

2. Bitwise XOR

3. Binary Search Tree

4. Tree Breadth-First Search & Tree Depth-Frist Search

1. AVL Tee or self-balancing binary search tree

2. Monotonic Queue

Some of the questions related to these common patterns need Leetcode premium; alternately, you can access the most important question sets from Grokking the Coding Interview.

## Conclusion

Most technical interviews include LeetCode-type questions. Software engineers practice such coding problems before interviews. The highest return on investment is achieved by preparing smartly and focusing on the top LeetCode interview patterns. You can learn more about popular coding interview patterns and related problems in Grokking the Coding Interview and Grokking Dynamic Programming for Coding Interviews.

Here are some more interview prep sources:

Amazon
Apple
Coding Interview
Coding Interview Questions
Coding Patterns
Data Structures and Algorithms
Dynamic Programming Patterns
FAANG