Open sakomws opened 5 years ago
Tech Interview Handbook (solve 50 suggested LCs multiple times): https://lnkd.in/dbK9TasP
Grokking Coding Interview: https://lnkd.in/d4YzR_3d
Solve each question yourself before looking at answers. After struggling with certain topics, found some youtube resources that were really helpful.
I would say 1/2 of my coding questions was graph related, and I used topsort, MST, union find during my interviews so its worth knowing them well.
Great resource on Binary Search (esp. for harder variants): https://lnkd.in/dPVikn9e
Quite a few LC hards involve binary search as part of its solution, but its non-obvious.
At staff level, you are expected to have great communication, come up with one or more high level solutions in reasonable time with space and time complexity, implement mostly correct, and check for errors independently.
Always ask clarifying questions, they are meant to be vague.
No. 1 tip: Pay for mock interviews, take extensive notes, study, pay for more interviews. I used igotanoffer.com. Try booking different interviewers, they have different expectations, communication, friendliness.
Grokking system design: https://lnkd.in/dKBtGDDG
It’s good to complete grokking, but in practice its a little too shallow for staff level.
Watch all videos and take notes from this channel: https://lnkd.in/d32sycXJ
Most other channels like Exponent are actually not great examples of a good interviewee for staff level.
Read papers on Dynamo, BigTable, MapReduce, Cassandra, Raft, Lamport Clocks, etc.
A lot of material written by this Medium writer is great: https://lnkd.in/d_4yxAA7
Memorize Jeff Dean’s latency numbers: https://lnkd.in/dq42yWsa
If you have time, read DDIA: https://dataintensive.net/
I memorized mnemonics for structure of how I execute my interview, as well as for each topic. Like OSI model, caching strategies, load balancing strategies, database types, etc. You need to make up your own in order to ingrain them.
For details: Pathrise guide