An initiative to empower the software engineer to excel in the interview.
Join our class: https://codinginterviewclass.com
YouTube: https://www.youtube.com/c/BackToBackSWE
The Exhaustive Topics A Software Engineer Needs To Know To Pass A Big N Interview:
- Fundamentals of Computer Systems (just a general knowing how computers store information etc.)
- Big O Time & Space Complexity Computation
- Arrays
- Primitives
- Strings
- Dynamic Programming
- Recursion / Backtracking
- Graphs
- Greedy Algorithms
- Hashtables
- Linked Lists
- Sorting
- Searching
- Min/Max Heaps
- Stacks
- Queues
- Trees, Binary Trees, & Binary Search Trees
- System and OO design Principles (sometimes)
And that is pretty much it. These are the topics you need to know well to pass.
The channel's goal is to contribute to the community of people bridging these topics to help engineers excel in the interview.
It has nothing to do with me. I am just here to communicate the ideas.
I am only a humble teacher, I am not perfect.
If even one person gets an offer from my work my day is complete.
I'd love any contributions from people to this repo. I just restructured it so that solutions in multiple languages can be added for a single problem.
Just make sure that you follow the style conventions of your respective language.
- The code has to pass all test cases (if from Leetcode or any other site). It'd even be helpful if in the code you notate what date all tests passed so readers can know when a file needs updating (if tests fail all of a sudden or if a Leetcode structure changed and nothing compiles)
- If the problem doesn't have an "origin website" that has test cases, make a small driver function that can call the solution code with example inputs so others can test and play with the code.
- Less lines of code is not always better. This is close to the ternary rule above, but generally syntax shortcuts will not change what a program ultimately is transformed to. Balance understandabiltiy & brevity.
- I like comments in teaching code. This code is meant to instruct and is not part of a huge codebase, so it is fine to go heavy on comments. Each file is disjoint, static, & ages individually, so stale comments are less of a worry. I do it a bit too much in older samples, but I think you can find the balance.
I'm not perfect. I watch finished videos 2 times over. I read and test all code samples. But I still make errors.
If you see a mistake anywhere just open a pr & I'll merge it in.
Sometimes Leetcode function signatures change or the names on fields of objects change breaking the code. If you see this then just open an issue or pr if you want to fix it.
no affiliate links here
Bare Beginner: https://www.amazon.com/Cracking-Coding-Interview-Programming-Questions/dp/0984782850 Medium/Advanced: https://www.amazon.com/Elements-Programming-Interviews-Java-Insiders/dp/1517671272 Advanced: https://cses.fi/book/
My Comments: Cracking The Coding Interview is a good start but pales in comparison to how much Elements of Programming Interviews (EPI) will prepare you for the interview. Everything that I do has been inspired by this book. To date, I have read it nearly 5 times and skimmed it 4 times.