cracking-maang
cracking-maang copied to clipboard
π₯· Cracking the MAANG Interviews | Google & Bloomberg | Algorithms and Data Structures | Tips and Resources
Cracking the Coding Interview
Rustam-Zπ β’ 8 June 2021
Join my Telegram channel: @cracking_swe, where I share MAANG interview preparation resources.
data:image/s3,"s3://crabby-images/e2f0a/e2f0a08d6ce5a1675089e955749ecfbe0e7a96bf" alt=""
Contents
- General plan
- How to approach solving algorithm?
- Algorithms & data structures topics
- Algorithms learning preparation plan
- System Design
- Extra Resources
General plan
- Learn DS and Algorithms
- Solve algorithms
- Repeat concepts
- Learn System Design
- Write a resume
- Prepare for a behavioral interview
- Find people for referral and apply
- Pass the interview
- Get an offer, and negotiate salary! πΎ
How to approach solving the algorithm?
Constraints, Ideas, Complexities, Code, and Tests
- Read the problem. Donβt immediately jump into coding!
- Understand inputs & outputs. Draw some examples on paper.
- Ask questions, and find constraints. Find edge cases. Example questions: is it ASCII or Unicode? what is the Max value? is there a difference between capital letters and small letters?
- Thinking about the solution in mind. Divide problems into sub-problems.
- Evaluate the complexity
- Think better alternative solution
- Write code on paper
- Debug your code on paper and test with new corner case inputs
- Write code and write tests
Algorithms Learning Plan
- [ ] The Last Algorithms Course You'll Need
- [ ] interviewbit.com & interviewcake.com & programiz.com/dsa
- [ ] LeetCode Explore
- [ ] LeetCode study plan β Data Structure 1, Algorithm 1, Programming Skills 1
- [ ] "Cracking the coding interview" + CTCI problems in LeetCode
- [ ] LeetCode study plan β Data Structure 2, Algorithm 2, Programming Skills 2
- [ ] AlgoExpert video solutions
- [ ] neetcode.io & NeetCode playlist
- [ ] LeetCode company tagged questions
System Design Learning Plan
- [ ] "Systems Expert" from AlgoExpert
- [ ] "System Design Interview" book - 1st and 2nd editions
- [ ] "Grokking the System Design Interview" (educative.io)
- [ ] "Designing Data-Intensive Applications" book
- [ ] Tushar
Extra Resources
- Article by Sergey Sema
- InterviewPreparationGuide.pdf
- faang-interview.github.io
- docs.outtalent.com/guides
- Coding interview tips
Algorithms & Data Structures Readings
- https://www.hiredintech.com/classrooms/algorithm-design/lesson/78
- https://www.techinterviewhandbook.org/algorithms/study-cheatsheet/
- https://medium.com/swlh/taking-the-edge-off-of-edge-cases-7b3008d83a57
Topics
- Big-O = how quickly the runtime grows relative to the input as the input gets arbitrarily large.
- Strings
- ASCII, Unicode
- How are strings implemented in your programming language (for example, is there a maximum length)?
- Search for substrings (for example, the Rabin-Karp algorithm).
- RegEx
- Arrays
- Details of implementation in your programming language. For example, for C++ you need to know the implementation using pointers, and vectors. For vectors, you also need to know, for example, that it periodically does resize, and other similar details.
- Linked lists
- Singly linked list
- Doubly linked list
- Stacks and Queues
- Trees
- DFS, BFS
- Adding and removing elements
- Less common tree types (e.g., red black trees, B-trees) - what are they, how they differ from the binary trees, basic complexities, and how they are used. No need to know all the rotations in the RB-tree, for example.
- Tries
- Heaps
- Heap sort
- Using heaps for tracking top-K
- Allocating elements on a heap vs on a stack - what does it mean?
- Graphs
- DFS, BFS
- Topological search
- Shortest path
- Hash
- Hash functions
- Universal hash
- Algorithms
- Sorting
- Especially make sure you know heap sort, merge sort and quick sort.
- Searching
- Binary search
- Searching in linked lists, arrays, trees, graphs, dictionaries...
- Dynamic programming = problems, which are problems where the solution is composed of solutions to the same problem with smaller inputs.
- Bottom-up
- Top-down
- Backtracking = Backtracking is an algorithmic technique for solving problems recursively by trying to build a solution incrementally, one piece at a time.
- Greedy algorithms
- Recursion
- Sorting