16 Algorithmic Tricks
16 Algorithmic Tricks
16 Algorithmic Tricks
to solve a
Coding Question
in an
Interview
DesignGurus.org
1. Sliding Window
Use sliding window technique
for problems that involve
handling the input data in a
specific window size.
DesignGurus.org
2. HashTable
Use HashTable to improve the
time complexity of lookups and
other operations.
DesignGurus.org
3. Two Pointers
Use the two pointers technique
for problems that involve
pointers traversing an array. The
pointers can move in opposite
or the same directions and
sometime they move with
different speed like the case with
Fast and Slow pointer approach.
DesignGurus.org
4. Backtracking
Use backtracking or brute force
to generate all possible solutions
and then filter them based on
constraints.
DesignGurus.org
5. Greedy Algorithms
Use greedy algorithms for
problems with an optimal
substructure property.
DesignGurus.org
6. Divide and Conquer
Use divide and conquer for
problems that can be broken
down into subproblems.
DesignGurus.org
7. Dynamic Programming
Use dynamic programming or
memoization to optimize
recursive solutions.
DesignGurus.org
8. Recursion
Use recursion to simplify the
problem and make it more
elegant.
DesignGurus.org
9. Binary Search
Use binary search for problems
that involve searching for a
specific value in a sorted array or
list.
DesignGurus.org
10. BFS and DFS
Use breadth-first search (BFS) or
depth-first search (DFS) for
problems that involve traversing a
tree or a graph.
DesignGurus.org
11. Meet-in-the-Middle
Use the Meet-in-the-middle
technique to solve problems that
can be broken down into two
subproblems that can be solved
independently.
DesignGurus.org
12. Recursion Tree
Use the recursion tree method to
visualize and analyze the time
complexity of recursive solutions.
DesignGurus.org
13. Union-Find
Use the Union-Find algorithm for
solving problems that involve
disjoint sets, such as detecting
cycle in a graph, Kruskal's
minimum spanning tree algorithm.
DesignGurus.org
14. Trie
Use the Trie data structure for
problems that involve searching
for strings, such as auto-complete,
spell-checking, IP routing.
DesignGurus.org
15. Binary Search Tree
Use the Binary search tree for
storing data, where you can
perform operation like search,
insert, delete, in O(log n) time.
DesignGurus.org
16. Segment Tree
Use the Segment Tree/Fenwick
Tree for Range Queries and
Updates in an array/list.
DesignGurus.org
➡ Follow these techniques to distinguish
yourself from others!
DesignGurus.org